A wait可以被另一个notify正在等待等待的监视器调用的线程“唤醒”
sleep。此外,
wait(和notify)必须在
synchronized监视对象的块中发生,而sleep不会:
Object mon = ...;synchronized (mon) { mon.wait();} 此时,当前正在执行的线程将等待并释放监视器。另一个线程可能会做
synchronized (mon) { mon.notify(); }(在同一mon对象上),第一个线程(假设它是监视器上等待的唯一线程)将被唤醒。
你还可以
notifyAll在监视器上等待多个线程的情况下进行调用-这将唤醒所有线程。但是,只有一个线程将能够抓住监视器(请记住,它们wait在一个synchronized块中)并继续运行-然后其他线程将被阻塞,直到它们可以获取监视器的锁为止。
另一点是,你叫
wait上
Object本身(即你等待对象的监视器上),而你打电话
sleep的
Thread。
另一个问题是,你可以得到虚假唤醒从
wait(即线程正在等待简历没有明显的原因)。在以下情况下,你应始终
wait旋转:
synchronized { while (!condition) { mon.wait(); }}


