synchronized(obj) {
while(!condition) {
obj.wait;
}
obj.doSomething;
}
当线程A获得了obj锁后发现条件condition不满足无法继续下处理于是线程A就wait
在另线程B中如果B更改了某些条件使得线程Acondition条件满足了就可以唤醒线程A:
synchronized(obj) {
condition = true;
obj.noty;
}
需要注意概念是:
# objwait, noty思路方法前必须获得obj锁也就是必须写在synchronized(obj) {...} 代码段内
# obj.wait后线程A就释放了obj锁否则线程B无法获得obj锁也就无法在synchronized(obj) {...} 代码段内唤醒A
# 当obj.wait思路方法返回后线程A需要再次获得obj锁才能继续执行
# 如果A1,A2,A3都在obj.wait则Bobj.noty只能唤醒A1,A2,A3中个(具体哪个由JVM决定)
# obj.notyAll则能全部唤醒A1,A2,A3但是要继续执行obj.wait下条语句必须获得obj锁因此A1,A2,A3只有个有机会获得锁继续执行例如A1其余需要等待A1释放obj锁的后才能继续执行
# 当Bobj.noty/notyAll时候B正持有obj锁因此A1,A2,A3虽被唤醒但是仍无法获得obj锁直到B退出synchronized块释放obj锁后A1,A2,A3中个才有机会获得锁继续执行
最新评论