这个三个函数来自Object类,众所周知它们是用于多线程同步的。
然而,有个问题却一直没搞清楚,即notify()函数到底通知谁?
《Thinking in JAVA》中有这么一句话,当notify()函数因为某个特定锁被调用时,只有等待
这个锁的任务才会被唤醒。
什么意思?
看下面的代码,这个代码执行的话会报错,java.lang.IllegalMonitorStateException
上网查了一下,明白了。
1>当前线程不含有当前对象的锁资源的时候,调用obj.wait()方法;2>当前线程不含有当前对象的锁资源的时候,调用obj.notify()方法。3>当前线程不含有当前对象的锁资源的时候,调用obj.notifyAll()方法。
public class Apple implements Runnable{ public static Object apple=new Object(); @Override public void run() { synchronized(apple) { System.out.println("apple locked"); try { wait(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } System.out.println("apple run end"); } }
把上面代码的 synchronized(apple)
改为 synchronized(this)就不报错类
原来,只有当前线程拥有了对象A的锁的时候,才能在A上调用wait函数,那么,此时,这个线程就是
在对象A上等待。
如果其他线程调用类A.notify(),那么在A上等待的线程就会醒来。
那么还有个问题,因为notify函数的调用也需要获取该对象的锁,而wait已经取得了这个锁,那么岂不是自相矛盾了?
原来在进入wait()函数之后,线程会自动的把自己拥有的所有锁都释放掉。这样其他线程就可以重新获得这些锁,利用
这些锁做一些事,使得某些条件得到满足之后再通知之前wai的线程。
时间: 2024-10-27 18:40:43