生产者消费者模式(wait(),notify())

本文通过一个生产者消费者模型的示例,详细解释了Java中wait()和notify()方法在线程同步中的作用。这两个方法用于在同步块内协调线程间的操作,确保线程安全。生产者线程在仓库不空时调用wait()等待,消费者线程在仓库为空时调用wait()等待。当条件满足时,通过notify()唤醒等待的线程,实现资源的有效利用。
摘要由CSDN通过智能技术生成
  • wait()和notify()方法建立在线程安全的基础上,必须在synchronized 代码块里执行,且成对 出现
  • 两个方法不是thread的方法,是java的方法
  • 当调用wait() 方法后,当前线程(t线程)立刻进入无限等待状态,并且 释放当前线程占有的锁
  • 直到调用notify() 方法,才可以让t线程唤醒
  • notify() 方法只会通知,不会释放锁
  • waitnotify程序才能被唤醒,否则程序一直无法结束
public class ThreadTest11 {
    public static void main(String[] args) {
        List list = new ArrayList();
        Thread t1 = new Thread(new Producer(list),"生产者线程");
        Thread t2 = new Thread(new Consumer(list),"消费者线程");

        t1.start();
        t2.start();


    }
}

//生产线程
class Producer implements Runnable{

    //仓库
    private List list;

    public Producer(List list){
        this.list = list;
    }
    @Override
    public void run() {
       while(true){
            synchronized (list) {
                if (list.size() > 0) { //仓库不为空,则满(假设仓库容量为1)
                    try {
                        list.wait(); //线程进入等待状态,释放锁
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                Object obj = new Object();
                list.add(obj);
                System.out.println(Thread.currentThread().getName()+"--->"+obj);
                list.notify();
                System.out.println("生产者");
            }
        }
    }
}

//消费线程
class Consumer implements Runnable{

    private List list;

    public Consumer(List list){
        this.list = list;
    }

    @Override
    public void run() {
        while (true){
            synchronized (list){
                if (list.size() == 0){ //仓库为空
                    try {
                        list.wait();  //线程进入等待,释放锁
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                Object obj = list.remove(0);
                System.out.println(Thread.currentThread().getName()+"--->"+obj);
                list.notify(); //唤醒wait线程,但没有释放锁,只有循环结束才会释放锁
                System.out.println("消费者");
            }

        }
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值