这个三个函数来自Object类,众所周知它们是用于多线程同步的。
然而,有个问题却一直没搞清楚,即notify()函数到底通知谁?
《Thinking in JAVA》中有这么一句话,当notify()函数因为某个特定锁被调用时,只有等待
这个锁的任务才会被唤醒。
什么意思?
看下面的代码,这个代码执行的话会报错,java.lang.IllegalMonitorStateException
上网查了一下,明白了。
1>当前线程不含有当前对象的锁资源的时候,调用obj.wait()方法;
2>当前线程不含有当前对象的锁资源的时候,调用obj.notify()方法。
3>当前线程不含有当前对象的锁资源的时候,调用obj.notifyAll()方法。
public class Apple implementsRunnable{public static Object apple=newObject();
@Overridepublic voidrun() {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的线程。