public class SimpleWN {
final static Object object = new Object();
public static class T1 extends Thread{
public void run ( ){
synchronized (object) {
System.out.println(System.currentTimeMillis()+":T1 statr!");
try {
System.out.println(System.currentTimeMillis()+": T1 wait for object!");
object.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(System.currentTimeMillis()+":T1 end!");
}
}
}
public static class T2 extends Thread{
public void run () {
synchronized (object) {
System.out.println(System.currentTimeMillis()+":T2 start! notify one thread");
object.notify();
System.out.println(System.currentTimeMillis()+":T2 end!");
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
public static void main(String[] args) {
Thread t1 = new T1();
Thread t2 = new T2();
t1.start();
t2.start();
}
}
上述代码中,开启了两个线程T1 和 T2。T1 执行了object.wait()方法。注意,在程序的T1线程执行wait()方法前,T1 先申请object的对象锁。因此,在执行 object.wait()时,它是持有object的锁的。wait()方法执行后,T1会进行等待,并释放object的锁。T2 在执行notify() 之前也会先获得object的对象锁。这里为了让效果更佳明显,在notify()执行之后,让T2 休眠2秒钟,这样做可以更明显的说明,T1 在得到notify()通知后,还是会先尝试重新获得object的对象锁。上述代码的执行结果如下:
程序打印的时间戳信息,可以看到,在T2通知T1继续执行后,T1并不能立即继续执行,而是要等待T2释放object的锁,并重新成功获得锁后,才能继续执行。
注意:Object.wait() 和 Thread.sleep() 的方法都可以让线程等待若干时间。除了wait()可以被唤醒外,另外一个主要区别就是 wait() 方法会释放目标对象的锁,而Thread.sleep()方法不会释放任何资源。