线程与线程之间不是独立的个体,他们彼此之间都是可以相互通信和协作的。比如有两个线程A和B,线程A做的是不断地对变量i进行累加,B做的通过while循环,当检测到i的值是10000时则打印出来,这样两个线程实现了通信,但是线程B不停地通过while语句轮询机制来检测某一个条件,这样会浪费CPU资源。因此我们需要一种机制来减少CPU的资源浪费而且还可以实现多个线程之间的通信,即“wait/notify”机制。
先看一个等待/通知的例子,当list.size()==5时进行通知。
MyList.java
public class MyList {
private static List list=new ArrayList();
public static void add(){
list.add("ltt");
}
public static int size(){
return list.size();
}
}
ThreadA.java
public class ThreadA extends Thread{
private MyList list;
public ThreadA(MyList list) {
super();
this.list=list;
}
public void run(){
try{
synchronized (list) {
if(list.size()!=5){
System.out.println("开始wait等待");
list.wait();
System.out.println("结束wait等待");
}
}
}catch(InterruptedException e){
e.printStackTrace();
}
}
}
<