一篇说到了suspend()和resume()方法,这一篇咋们继续,接着来介绍wait()和notify()方法,我们都知道这两个方法和之前介绍的方法不太一样,那就是这两个方法是对象Object上的,不属于Thread类上的。我们也知道这两个方法是实现多个线程之间的通信和互斥的,不多说了,下面就来看一下例子吧:
例子描述:
开启两个线程,子线程循环10次,主线程循环100次,如此反复循环50次
代码如下:
packagecn.itcast.heima;
publicclassTraditionalThreadCommunication {
publicstaticvoidmain(String[] args) {
finalBusiness business =newBusiness();
//子线程循环10次
newThread(newRunnable(){
@Override
publicvoidrun() {
for(inti=0;i<50;i++){
business.sub(i);
}
}
}).start();
//主线程循环100次
for(inti=0;i<50;i++){
business.main(i);
}
}
/**
* 业务逻辑类
* @author weijiang204321
*
*/
staticclassBusiness{
privatebooleanbShouldSub =true;//true表示sub执行,false表示main执行
publicsynchronizedvoidsub(inti){
//将这里的if改成while,效果更好,while会再次判断,安全性高
//因为有时候线程可能被假唤醒
while(!bShouldSub){
try{
//等待
this.wait();
} catch(InterruptedException e) {
e.printStackTrace();
}
}
for(intj=0;j<=10;j++){
System.out.println("sub thread sequece of"+ j +",loop of"+i);
}
bShouldSub = false;
this.notify();//唤醒该锁的等待线程
}
publicsynchronizedvoidmain(inti){
while(bShouldSub){
try{
this.wait();
} catch(InterruptedException e) {
e.printStackTrace();
}
}
for(intj=0;j<=100;j++){
System.out.println("main thread sequece of"+ j +",loop of"+i);
}
bShouldSub = true;
this.notify();
}
}
}
通过wait和notify机制来实现这两个线程的循环的有序性,能够保证子线程循环10次,主线程循环100次这样交替运行。
运行结果很多,这里就不截图了!这里我们也是可以看到的,调用wait方法是会释放锁的,所以他会被用到很多,这个和之前的几个方法是不同的!
注意的两点:
第一:同步代码块中的锁和调用wait和notifiy方法的对象锁一定要是同一个。
第二:wait和notify方法的调用一定要在同步代码块中,不然会报异常,可以自行测试一下。
不要因为这样就结束了,这一篇还不是最终篇,等待下一篇吧
http://blog.csdn.net/jiangwei0910410003/article/details/19962565