博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
wait,notify,notifyAll用法解析
阅读量:6229 次
发布时间:2019-06-21

本文共 1362 字,大约阅读时间需要 4 分钟。

在并发开发中,锁是非常常见的,而wait/notify也经常会和锁一起使用,例如在生产者消费者模式中。而且wait/notify也必须和锁一起使用,因为它们都是基于对象的,否则会抛出异常。

下面,我们通过一段简单的代码,来了解以下wait/notify的用法:

public class WaitNotifyTest {
public static final Object FINAL_OBJECT = new Object(); static class R implements Runnable{
@Override public void run() { synchronized (FINAL_OBJECT) { try { System.out.println(Thread.currentThread().getName()+"进入wait"); FINAL_OBJECT.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } System.out.println(Thread.currentThread().getName()+"运行完成"); } } public static void main(String[] args) throws InterruptedException { for (int i = 0; i < 3; i++) { new Thread(new R()).start(); } Thread.sleep(100); synchronized (FINAL_OBJECT) { FINAL_OBJECT.notify(); } }}

运行结果如下:

Thread-2进入waitThread-4进入waitThread-3进入waitThread-2运行完成

我们发现,线程2运行完成之后,线程3和线程4还是继续会等待,所以notify方法只会唤醒一个进入wait的线程,并且是第一个进入的。如果使用notifyAll,运行结果如下:

Thread-2进入waitThread-3进入waitThread-4进入waitThread-4运行完成Thread-2运行完成Thread-3运行完成

由此我们可以分析出:使用notifyAll会将所有的线程都唤醒,唤醒之后,谁先获取到CPU资源,谁就先执行,所以这三个线程的执行顺序出现了变化。

而且,通过以上代码,我们可以知道wait的一个特性:当线程进入wait状态时,该线程会将锁资源释放,其他的线程就可以进来,而当它再次被唤醒时,就可以再次去抢夺锁资源了。

转载地址:http://twina.baihongyu.com/

你可能感兴趣的文章
图的基本知识
查看>>
leetcode第一刷_Same Tree
查看>>
高速排序之算法导论实现
查看>>
$.post()提交了数据,return不给跳转
查看>>
检测和删除多余无用的css
查看>>
pip安装使用详解【转】
查看>>
Mybatis 中延时加载
查看>>
固本清源
查看>>
Execution Plan 执行计划介绍
查看>>
聊聊连接池和线程
查看>>
Python——正則表達式(2)
查看>>
适合新人学习的iOS官方Demo
查看>>
拉开大变革序幕(下):分布式计算框架与大数据
查看>>
AndroidStudio 使用AIDL
查看>>
H.264 RTPpayload 格式------ H.264 视频 RTP 负载格式(包含AAC部分解析)
查看>>
poj 3468 A Simple Problem with Integers 【线段树-成段更新】
查看>>
CentOS---网络配置详解
查看>>
第1阶段——uboot分析之硬件初始化start.S(4)
查看>>
记dynamic的一个小坑 -- RuntimeBinderException:“object”未包括“xxx”的定义
查看>>
代写初中语文作文|代写初中语文作文技巧分享
查看>>