上一篇说到了suspend()和resume()方法,这一篇咋们继续,接着来介绍wait()和notify()方法,我们都知道这两个方法和之前介绍的方法不太一样,那就是这两个方法是对象Object上的,不属于Thread类上的。我们也知道这两个方法是实现多个线程之间的通信和互斥的,不多说了,下面就来看一下例子吧:
例子描述:
开启两个线程,子线程循环10次,主线程循环100次,如此反复循环50次
代码如下:
-
package cn.itcast.heima;
-
-
public class TraditionalThreadCommunication {
-
-
public static void main(String[] args) {
-
final Business business = new Business();
-
-
new Thread(new Runnable(){
-
@Override
-
public void run() {
-
for(int i=0;i<50;i++){
-
business.sub(i);
-
}
-
}
-
}).start();
-
-
-
for(int i=0;i<50;i++){
-
business.main(i);
-
}
-
-
}
-
-
-
-
-
-
-
static class Business{
-
private boolean bShouldSub = true;
-
public synchronized void sub(int i){
-
-
-
while(!bShouldSub){
-
try {
-
-
this.wait();
-
} catch (InterruptedException e) {
-
e.printStackTrace();
-
}
-
}
-
-
for(int j=0;j<=10;j++){
-
System.out.println("sub thread sequece of" + j + ",loop of"+i);
-
}
-
bShouldSub = false;
-
this.notify();
-
}
-
-
public synchronized void main(int i){
-
while(bShouldSub){
-
try {
-
this.wait();
-
} catch (InterruptedException e) {
-
e.printStackTrace();
-
}
-
}
-
for(int j=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方法的调用一定要在同步代码块中,不然会报异常,可以自行测试一下。
不要因为这样就结束了,这一篇还不是最终篇,等待下一篇吧!