0
点赞
收藏
分享

微信扫一扫

生产者与消费者

婉殇成长笔记 2022-03-11 阅读 98

1,wait与notify:

wait和notify是java中任何一个对象都有的方法。

某对象调用wait()方法:在该对象上活动的线程进入等待状态,直到被唤醒。

某对象调用notify()方法,在该对象上的线程被唤醒。而notifyAll是唤醒所有等待的线程。

wait()方法会让当前对象进入等待状态,并释放对象锁。notify()方法只是通知,不进行释放。

2,生产者与消费者:

该模式是为了解决专门的需求。

一个线程负责生产,一个负责消费,最终需要达到生产消费相平衡。如图所示:

实现该模式:

public class test {
public static void main(String[] args) throws InterruptedException, ExecutionException {
List L=new ArrayList();
Thread pro=new Thread(new Producer(L));
Thread con=new Thread(new Consumer(L));
pro.setName("生产者");con.setName("消费者");
pro.start();con.start();

}
}
//用List模拟仓库,一个就表示满了
class Producer implements Runnable{
private List L;
public Producer(List L) {
this.L=L;
}
@Override
public void run() {
// TODO Auto-generated method stub
while(true) {
synchronized(L){
try {
Thread.sleep(1000);
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
if (L.size()>0) {
try {
L.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//L表示仓库,当仓库中大于0,停止生产,释放了对象锁拿给消费者
}
//进行生产
Object o=new Object();
L.add(o);
System.out.println(Thread.currentThread().getName()+":"+o);
L.notify();
//唤醒消费者线程,但不会释放锁
}
}
}
}
class Consumer implements Runnable{
private List L;
public Consumer(List L) {
this.L=L;
}
@Override
public void run() {
// TODO Auto-generated method stub
while(true) {
synchronized(L) {
try {
Thread.sleep(1000);
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
if (L.size()==0) {
try {
L.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//当L为0时,停止消费
}
System.out.println(Thread.currentThread().getName()+":"+L.get(0));
L.remove(0);
L.notify();
//唤醒生产者
}
}
}
}
举报

相关推荐

0 条评论