下面这个代码是测试 wait 与 notify 方法的用法,在新创建出来的线程中调用 wait 方法阻塞当前线程,并释放锁资源,在主线程中调用 notify 方法唤醒阻塞的线程时,发生 IllegalMonitorStateException 异常。
package Thread;
public class WaitNotifyDemo implements Runnable {
private static final Object lock1 = new Object();
private static final Object lock2 = new Object();
@Override
public void run() {
System.out.println("enter");
try {
synchronized (lock1) {
lock1.wait();
}
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("exit");
}
public static void main(String[] args) throws InterruptedException {
new Thread(new WaitNotifyDemo()).start();
Thread.sleep(2000);
lock1.notify();
}
}
查看源码后发现要使用 notify、notifyAll、wait 这三个方法,调用该方法的线程必须获得该对象的 monitor 对象(也就是获取该对象的锁资源),否则就会报 IllegalMonitorStateException。
在主线程中获取的是 lock2 的锁资源,在同步块中调用 lock1 的 notify 方法也同样会报错。
主线程获取到 lock1 的锁资源后,再调用 notify 方法就不会报错了