• 多线程---等待唤醒机制


    线程执行当中,线程是放在线程池中的。 

    线程运行当中通常使用了wait()方法等待的话,再使用notify()唤醒线程,通常唤醒的是线程池中等待的第一个线程。

    而用notifyAll()则是唤醒全部线程 。

    以上三种红字的方法:

    wait()、notify()、notifyAll()必须使用在同步synchronized中

    因为对持有监视器(锁)的线程才能操作。

    注意:

    这三种方法 wait()、notify()、notifyAll()是定义在java.lang.Object这个父类当中的,线程是从这继承来的。

    为什么要定义在父类java.lang.Object中呢?

    是因为在操作线程时候,必须要标示他们操作线程锁持有的“锁”,只有同一个锁的等待线程 ,可以被notify()唤醒。

    而“锁” 可以是任意对象,所以可以被任意对象调用的方法定义在Object中。

     当用生产者消费者的这种模式的时候,也就是多个线程同时“生产”、“消费”

    要注意两点:

    要用while循环判断代替if判断,这样就不会出现已经判断了的等待线程再次获得执行资格时,会再次判断是否满足条件,这样生产者(消费者)就会全部等待;

    要用notifyAll来全部唤醒,如果只用notify那么就有可能只唤醒本方的线程(上一个条件会使对方全部等待),对方的不会被唤醒,这样才不会出现死锁的现象;

     JDK1.5之后提供了多线程的解决方案

    将同步中的synchronized操作替换成了显示的Lock

    Object中的waite,notify,notifyAll对象,替换成了Condition

    这个对象可以Lock锁   进行获取

     

  • 相关阅读:
    win10 创建安卓模拟器及启动的方法
    win10 virtualenv
    win10安装nodejs
    python模块打包方法
    win10 安装java
    git push后自动部署
    ubuntu配置无密码登录
    mysql while,loop,repeat循环,符合条件跳出循环
    centos 安装mysql密码修改后还是不能连接的原因
    查看SQLServer数据库信息的SQL语句
  • 原文地址:https://www.cnblogs.com/kevinfuture/p/4285377.html
Copyright © 2020-2023  润新知