wait / notify
当线程A获得了 obj 锁后,如果条件 condition 不满足就 wait()
---------thread A----------------
synchronized(obj) {
while(!condition) {
obj.wait();}
obj.doSomething();
}
线程B更改了某些条件,使得线程A的 condition 条件满足了,就唤醒线程A
---------thread B----------------
synchronized(obj) {
condition = true;
obj.notify();
}
调用obj的wait(), notify()前,必须先获得obj锁, 调用obj.wait()后,线程A就释放了obj的锁, 当obj.wait()方法返回后,线程A需要再次获得obj锁才能继续执行, 如果A1,A2,A3都在obj.wait(),则B调用obj.notify()只能唤醒A1,A2,A3中的一个
obj.notifyAll()能全部唤醒A1,A2,A3,但是要继续执行obj.wait()的下一条语句,必须获得obj锁,需等到B退出synchronized块后,A1,A2,A3只有一个有机会获得锁继续执行,其余的需要等待锁释放才能继续执行
wait 和 notify 本质是基于条件对象,而且只能由已经获得锁的线程调用,java 的每个 Object 都有一个隐式锁,这个隐式锁关联一个 Condition 条件对象,线程拿到这个隐式锁(比如进入 synchronized 代码区域),就可以调用 wait,语义是在 Condition 条件对象上等待,其他的线程可以在这个 Condition 条件对象上等待,等满足条件之后,就可以调用 notify 或者 notifyAll 来唤醒所有在此条件对象上等待的线程