你说的这种情况属于同步嵌套,所以在操作同步线程的时候必须在wait(),notify()之前标识出它们操作的线程所属的锁,只有同一个锁上的被等待线程,可以被同一个锁上notify唤醒,也就说等待和唤醒必须是同一个锁。下边是API中的解释,你看一下,wait()前面是不是有obj标识对吧?
当前线程必须拥有此对象监视器。该线程发布对此监视器的所有权并等待,直到其他线程通过调用 notify 方法,或 notifyAll 方法通知在此对象的监视器上等待的线程醒来。然后该线程将等到重新获得对监视器的所有权后才能继续执行。
对于某一个参数的版本,实现中断和虚假唤醒是可能的,而且此方法应始终在循环中使用:
synchronized (obj) {
while (<condition does not hold>)
obj.wait();
... // Perform action appropriate to condition
}
|