生产者-消费者问题是一个经典的线程框架
生产者:
代码:
class cubbyHole{
private int index = 0;
priavte int []data = new int[3];
public **synchronized** void put(int value){
while(index == data.length){
try{
this.wait();
}catch(interruptedException e){
system.out.println("异常")}
}
data[index]
}
}
我们这里有个数组,生产者往数组里放数字,当数组存满后需要执行wait()等待,等待什么呢?等待消费者去取数组中的数字
消费者
代码:
public synchronized int get(){
while(index <=0){
try{
this.wait();
}catch(Exception e){}
}
index --;
int val = data[index];
this.notify();
return val;
当生产者给消费者信号后,消费者会执行取数组中的数字的动作,当取完后再发信号给生产者,生产者继续向数组中写数字。
当然使用wait可能会造成线程的死锁。发生线程死锁的情况多种多样
java针对死锁情况增加了很多工具类去帮助解决死锁的情况。
java.util.concurrent.locks
Lock接口、reentrantlock类、readWriteLock接口等等。。。