Java实现简易生产者消费者模型

Java实现简易生产者消费者模型

1.首先我们要知道什么是生产者消费者模型

生产者消费者模型是一种多线程设计模式,用于解决生产者线程和消费者线程之间的协调问题。

在生产者消费者模型中,生产者线程生成数据并将其加入队列,而消费者线程从队列中获取数据并进行消费。在生产者和消费者之间存在一个共享的缓冲区,它作为生产者和消费者之间的中间存储点,用于协调生产者和消费者的工作。

当生产者线程生成的数据太多时,它将被阻塞,直到消费者线程消费了一些数据,使队列不再满。当队列不满时,生产者线程才开始生产数据。反之,当队列为空时,消费者线程将阻塞,直到生产者线程生成了数据,消费者线程执行消费。

生产者消费者模型通常使用同步机制来解决生产者线程和消费者线程之间的协调问题,同步块用于保证对共享队列的访问是线程安全的。在Java中,可以使用关键字synchronized来实现同步。通俗来讲,当一个线程访问一个对象的同步块时,同步机制可以防止其他线程同时访问该对象。

2.代码实现

import java.util.LinkedList;//导入队列类 
import java.util.Queue;

class ProducerConsumer {
  private Queue<Integer> queue = new LinkedList<>();//创建队列对象
  private int limit = 10;
  private Object lock = new Object();//创建锁

  public void produce() throws InterruptedException {
    int value = 0;
    while (true) {
      synchronized (lock) {
        while (queue.size() == limit) {
          lock.wait();//队满,等待
        }
        queue.offer(value++);//队未满,生产
        lock.notify();//解锁,唤醒线程
      }
    }
  }

  public void consume() throws InterruptedException {
    while (true) {
      synchronized (lock) {
        while (queue.isEmpty()) {
          lock.wait();//队空,等待
        }
        int value = queue.poll();//移出队列
        System.out.println("Consumed: " + value);
        lock.notify();//解锁,唤醒线程
      }
      Thread.sleep(1000);
    }
  }
}

public class Main {
  public static void main(String[] args) {
    ProducerConsumer pc = new ProducerConsumer();
    Thread t1 = new Thread(new Runnable() {//创建线程1,生产
      public void run() {
        try {
          pc.produce();
        } catch (InterruptedException e) {
          e.printStackTrace();
        }
      }
    });

    Thread t2 = new Thread(new Runnable() {//创建线程2,消费
      public void run() {
        try {
          pc.consume();
        } catch (InterruptedException e) {
          e.printStackTrace();
        }
      }
    });

    t1.start();//执行线程1
    t2.start();//执行线程2

    try {
      t1.join();//在t1线程执行完之前,其他线程阻塞
      t2.join();//在t2程执行完之前,其他线程阻塞
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
  }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

nothing8727

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值