wait/notify浅析

wait/notify是线程间同步机制

原理

当调用这个对象的wait方法时,将当前线程放到这个线程列表里(类似一个map结构,key是对象,value是一个线程列表),当调用这个对象的notify方法时(调用notify的线程在“退出其同步块”的时候唤醒起最后一个进入wait状态的线程)从这个线程列表里取出一个来让其继续执行。

具体过程

wait处理过程中会临时释放同步锁。

当某个线程调用notify唤起了这个线程的时候,在wait方法退出之前会重新获取这把锁。

wait方法被唤醒起来的时候会去检测线程状态,当有别的线程interrupt它的时候,它就会抛出InterruptedException异常从阻塞状态恢复过来

notify和notifyAll

notify来唤起的线程,那先进入wait的线程会先被唤起来
nootifyAll唤起的线程,默认情况是最后进入的会先被唤起来,即LIFO的策略

notifyAll的实现是调用notify的线程在退出其同步块的时候唤醒起最后一个进入wait状态的线程,然后这个线程退出同步块的时候继续唤醒其倒数第二个进入wait状态的线程,依次类推

性能

当线程进入到wait状态的时候会放弃cpu,不会占用cpu资源,load不会有影响

demo

new Thread(){
    public void run(){
        synchronized (lock){
            try{
                lock.wait();
            }catch (InterruptedException e){
                e.printStackTrace();
            }
        }
    }
}.start();

new Thread(){
    public void run(){
        synchronized (lock){
            lock.notify();
        }
    }
}.start();

底层实现技术

有兴趣的同学也可以继续深入学习

  • park/unpark机制
  • monitorenter/monitorexit
  • linux系统调用pthread_cond_wait/pthread_cond_signal

参考资源

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值