java wait(),notify(),notifyAll()的理解

这个三个函数来自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的线程。

 

posted @ 2016-08-27 11:22  ElNinoT  阅读(2014)  评论(0编辑  收藏  举报