Java多线程-生产者消费者模式

那什么是生产者消费者模式?

在一个生产环境中,生产者负责向缓冲区内添加商品(添加数据),消费者负责从缓冲区取出数据。

最经典的现实案例就是KFC,厨师(生产者)向存储汉堡的货柜(缓冲区)中添加汉堡(添加数据),消费者去点餐,购买汉堡(取出数据)。这就是最简单的生产者消费者模式。

1.汉堡类,所需要基本数据对象

//设置数据对象的基本属性,这里使用最简单的id
public class Hamburger {
    //设置商品的属性
    private Integer id;

    public Hamburger(Integer id) {
        this.id = id;
    }

    @Override
    public String toString() {
        return "Hamburger{" +
                "id=" + id +
                '}';
    }
}

2.制作装汉堡的容器,缓冲区存放生产者生产的数据对象

//创建容器
public class Container {
    //定义一个数组来装汉堡
    //当然这里也可以用集合框架ArrayList<Hamburger>来进行存储数据
    public Hamburger[] array = new Hamburger[6];
    public int index = 0;

    //对每次操作添加锁,避免多个线程操作同一个资源
    //也可以使用重入锁ReentrantLock
    /*
    *ReentrantLock使用方法:
        1.创建ReentrantLock对象
            private ReentrantLock reentrantLock = new ReentrantLock();
        2.加锁:
            reentrantLock.lock();
        3.解锁:
            reentrantLock.unlock();
    *两个方法间就是锁住的内容,资源
    */
    //向容器中添加汉堡
    public synchronized void push(Hamburger hamburger){
        if(index < array.length){
            array[index] = hamburger;
            index++;
            System.out.println("生产了一个汉堡:" + hamburger);
        }
    }

    //从容器中取出汉堡
    public synchronized Hamburger pop(){
        if(index>0){
            index--;
            System.out.println("消费了一个汉堡:" + array[index]);
            return array[index];
        }
        return null;
    }
}

3.创建生产者线程:

//生产者
public class Producer implements Runnable {
    //创建容器对象
    private Container container = null;

    public Producer(Container container) {
        this.container = container;
    }
    @Override
    public void run() {
        for (int i = 0; i < 30; i++) {
            //创建带编号的汉堡对象
            Hamburger hamburger = new Hamburger(i);
            //将汉堡装入容器中
            this.container.push(hamburger);
            try {
                //线程休眠
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

4.创建消费者线程

public class Consumer implements Runnable {
    //创建容器对象
    private Container container = null;

    public Consumer(Container container) {
        this.container = container;
    }
    @Override
    public void run() {
        for (int i = 0; i < 30; i++) {
            //购买汉堡
            this.container.pop();
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

5.测试类

public class Test {
    public static void main(String[] args) {
        //创建生产者,消费者,容器对象
        Container container = new Container();
        Producer producer = new Producer(container);
        Consumer consumer = new Consumer(container);
        //开启生产者,消费者线程
        new Thread(producer).start();
        new Thread(producer).start();
        new Thread(consumer).start();
        new Thread(consumer).start();
        new Thread(consumer).start();
    }
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
多线程生产者消费者模式是一种常见的并发编程模式,用于解决生产者和消费者之间的数据交互问题。在Java中,可以使用多线程和相关的同步机制来实现生产者消费者模式。 在这种模式中,生产者负责生成数据,并将数据放入共享的缓冲区中,而消费者则从缓冲区中取出数据进行处理。为了保证线程安全和避免竞态条件,需要使用锁或其他同步机制来控制对共享缓冲区的访问。 以下是一个简单的Java多线程生产者消费者的示例代码: ```java import java.util.LinkedList; class ProducerConsumer { private LinkedList<Integer> buffer = new LinkedList<>(); private int capacity = 10; public void produce() throws InterruptedException { int value = 0; while (true) { synchronized (this) { while (buffer.size() == capacity) { wait(); } System.out.println("Producer produced: " + value); buffer.add(value++); notify(); Thread.sleep(1000); } } } public void consume() throws InterruptedException { while (true) { synchronized (this) { while (buffer.isEmpty()) { wait(); } int value = buffer.removeFirst(); System.out.println("Consumer consumed: " + value); notify(); Thread.sleep(1000); } } } } public class Main { public static void main(String[] args) { ProducerConsumer pc = new ProducerConsumer(); Thread producerThread = new Thread(() -> { try { pc.produce(); } catch (InterruptedException e) { e.printStackTrace(); } }); Thread consumerThread = new Thread(() -> { try { pc.consume(); } catch (InterruptedException e) { e.printStackTrace(); } }); producerThread.start(); consumerThread.start(); } } ``` 上述代码中,ProducerConsumer类维护了一个缓冲区buffer和一个容量capacity。生产者通过调用produce方法向缓冲区中添加数据,消费者通过调用consume方法从缓冲区中取出数据。在生产者和消费者的方法中,使用synchronized关键字来保证同一时间只有一个线程能够访问共享资源,并使用wait和notify方法来实现线程间的通信。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值