No5.线程的等待(wait)和通知(notify)

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()方法不会释放任何资源。

猜你喜欢

转载自blog.csdn.net/shasiqq/article/details/53928174