java wait()和notify()
下面用一个实例说明:
public class Demo
{
public static void main(String[] args)
{
ThreadDemo b=new
ThreadDemo();
b.start();
System.out.println("b is
start....");
synchronized(b)
{
try
{
System.out.println("Waiting
for b to complete...");
// b.wait(3000);
b.wait();
System.out.println("Completed.Now
back to main thread");
}catch
(InterruptedException e){}
}
System.out.println("Total
is :"+b.total);
}
}
class ThreadDemo extends Thread
{
int total;
public void run()
{
try {
Thread.sleep(2000);
synchronized(this)
{
System.out.println("ThreadB
is running..");
for
(int i=0;i<100;i++ )
{
total
+=i;
//
if(i==30){Thread.sleep(3000);} //当 i=30的时候,让当前线程睡眠3秒
System.out.println("total
is "+total);
}
this.notify();
}
} catch (InterruptedException
e1) {
e1.printStackTrace();
}
}
}
分析:ThreadDemo类继承Thread,在run()方法里使用了synchronized块给ThreadDemo对象上锁,并在
synchronized块中调用notify()方法,在主函数里也使用了synchronized块给ThreadDemo对象上锁,并使用
wait()方法。注意这里上锁都是ThreadDemo对象。
程序运行:运行main方法时产生一个主线程,通过ThreadDemo对象启动其线程,在运行到run()方法的时候产生一个子线程,这时候就有两个线 程,为了更好的看到效果,在run()方法里用Thread.sleep(2000);让当前线程睡眠2秒,这时还没有给ThreadDe对象上锁。而主 线程接着往下面执行,进入到同步块,直到b.wait();的时候,这时主线程进入睡眠,同时释放了锁(ThreadDe对象)。因此两秒钟以后,子线程 就可以获得锁,继续执行,执行到this.notify()时,就会通知主线程中的wait(),让主线程继续执行。
使用b.wait(3000);同样为了效果,在ThreadDemo类中的run()方法的循环语句中加入if(i==30){Thread.sleep(4000);} 。执行程序的时候你会发现,不管是否过了3秒钟,只要子线程已经执行到同步块的时候,主线程必须等,直到子线程执行结束,释放了锁,才能继续执行。
浙公网安备 33010602011771号