线程执行当中,线程是放在线程池中的。
线程运行当中通常使用了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锁 进行获取