zoukankan      html  css  js  c++  java
  • Lock的await/singal 和 Object的wait/notify 的区别(转载)

     

    在使用Lock之前,我们都使用Object waitnotify实现同步的。举例来说,一个producerconsumerconsumer发现没有东西了,等待,producer生成东西了,唤醒。

    线程consumer

    线程producer

    synchronize(obj){ 
        obj.wait();//没东西了,等待 
    }

    synchronize(obj){ 
        obj.notify();//有东西了,唤醒 
    }

    有了lock后,世道变了,现在是:

    lock.lock(); 
    condition.await(); 
    lock.unlock();

    lock.lock(); 
    condition.signal(); 
    lock.unlock();

    为了突出区别,省略了若干细节。区别有三点:

    1. 1. lock不再用synchronize把同步代码包装起来;
    2. 2. 阻塞需要另外一个对象condition
    3. 3. 同步和唤醒的对象是condition而不是lock,对应的方法是awaitsignal,而不是waitnotify

      为什么需要使用condition呢?简单一句话,lock更灵活。以前的方式只能有一个等待队列,在实际应用时可能需要多个,比如读和写。为了这个灵活性,lock将同步互斥控制和等待队列分离开来,互斥保证在某个时刻只有一个线程访问临界区(lock自己完成),等待队列负责保存被阻塞的线程(condition完成)。

      通过查看ReentrantLock的源代码发现,condition其实是等待队列的一个管理者,condition确保阻塞的对象按顺序被唤醒。

  • 相关阅读:
    递归练习:走台阶
    递归练习:计算最大公约数和最小公倍数
    递归练习:逆序输出一个十进制数的各位数字
    m4, autoconf
    Makefile 和 CMakeLists.txt
    Java中的String pool
    小米路由Mini刷Breed, 潘多拉和LEDE
    Centos 编译LEDE/OpenWrt
    Centos6下编译安装gcc6.4.0
    IntelliJ IDEA遇到Unable to parse template “Class”错误
  • 原文地址:https://www.cnblogs.com/xiaolang8762400/p/7072106.html
Copyright © 2011-2022 走看看