用java实现生产者和消费者模式

简介: 用java实现生产者和消费者模式

下面是一个使用Java实现生产者和消费者模式的简单示例:

import java.util.LinkedList;

public class ProducerConsumerExample {
   
    public static void main(String[] args) {
   
        Buffer buffer = new Buffer(5); // 缓冲区大小为5
        Producer producer = new Producer(buffer);
        Consumer consumer = new Consumer(buffer);

        Thread producerThread = new Thread(producer);
        Thread consumerThread = new Thread(consumer);

        producerThread.start();
        consumerThread.start();
    }
}

class Buffer {
   
    private LinkedList<Integer> queue;
    private int capacity;

    public Buffer(int capacity) {
   
        this.capacity = capacity;
        this.queue = new LinkedList<>();
    }

    public void produce(int item) throws InterruptedException {
   
        synchronized (this) {
   
            while (queue.size() == capacity) {
   
                wait();
            }

            queue.add(item);
            System.out.println("生产者生产了:" + item);
            notify();
        }
    }

    public void consume() throws InterruptedException {
   
        synchronized (this) {
   
            while (queue.isEmpty()) {
   
                wait();
            }

            int item = queue.remove();
            System.out.println("消费者消费了:" + item);
            notify();
        }
    }
}

class Producer implements Runnable {
   
    private Buffer buffer;

    public Producer(Buffer buffer) {
   
        this.buffer = buffer;
    }

    @Override
    public void run() {
   
        try {
   
            for (int i = 1; i <= 10; i++) {
   
                buffer.produce(i);
                Thread.sleep(1000); // 模拟生产者生产的时间
            }
        } catch (InterruptedException e) {
   
            e.printStackTrace();
        }
    }
}

class Consumer implements Runnable {
   
    private Buffer buffer;

    public Consumer(Buffer buffer) {
   
        this.buffer = buffer;
    }

    @Override
    public void run() {
   
        try {
   
            for (int i = 1; i <= 10; i++) {
   
                buffer.consume();
                Thread.sleep(2000); // 模拟消费者消费的时间
            }
        } catch (InterruptedException e) {
   
            e.printStackTrace();
        }
    }
}

上面的代码中,我们定义了一个Buffer类作为缓冲区,它维护一个LinkedList作为队列来存放生产者生产的数据。

生产者线程通过调用produce方法向缓冲区中添加数据,如果缓冲区已满,则生产者线程会等待,直到有空间可用并通知消费者线程。

消费者线程通过调用consume方法从缓冲区中消费数据,如果缓冲区为空,则消费者线程会等待,直到有数据可消费并通知生产者线程。

main方法中,我们创建了一个Buffer实例,并创建生产者和消费者线程并启动它们。

运行代码后,你将会看到生产者不断地生产数据,而消费者不断地消费数据,它们之间通过缓冲区实现了同步和通信。

相关文章
|
25天前
|
安全 Java
Java多线程通信新解:本文通过生产者-消费者模型案例,深入解析wait()、notify()、notifyAll()方法的实用技巧
【10月更文挑战第20天】Java多线程通信新解:本文通过生产者-消费者模型案例,深入解析wait()、notify()、notifyAll()方法的实用技巧,包括避免在循环外调用wait()、优先使用notifyAll()、确保线程安全及处理InterruptedException等,帮助读者更好地掌握这些方法的应用。
16 1
|
2月前
|
存储 Java 开发者
【Java新纪元启航】JDK 22:解锁未命名变量与模式,让代码更简洁,思维更自由!
【9月更文挑战第7天】JDK 22带来的未命名变量与模式匹配的结合,是Java编程语言发展历程中的一个重要里程碑。它不仅简化了代码,提高了开发效率,更重要的是,它激发了我们对Java编程的新思考,让我们有机会以更加自由、更加创造性的方式解决问题。随着Java生态系统的不断演进,我们有理由相信,未来的Java将更加灵活、更加强大,为开发者们提供更加广阔的舞台。让我们携手并进,共同迎接Java新纪元的到来!
63 11
|
2月前
|
设计模式 Java
Java设计模式-工厂方法模式(4)
Java设计模式-工厂方法模式(4)
|
3月前
|
消息中间件 Java
【实战揭秘】如何运用Java发布-订阅模式,打造高效响应式天气预报App?
【8月更文挑战第30天】发布-订阅模式是一种消息通信模型,发送者将消息发布到公共队列,接收者自行订阅并处理。此模式降低了对象间的耦合度,使系统更灵活、可扩展。例如,在天气预报应用中,`WeatherEventPublisher` 类作为发布者收集天气数据并通知订阅者(如 `TemperatureDisplay` 和 `HumidityDisplay`),实现组件间的解耦和动态更新。这种方式适用于事件驱动的应用,提高了系统的扩展性和可维护性。
67 2
|
3月前
|
设计模式 XML 存储
【二】设计模式~~~创建型模式~~~工厂方法模式(Java)
文章详细介绍了工厂方法模式(Factory Method Pattern),这是一种创建型设计模式,用于将对象的创建过程委托给多个工厂子类中的某一个,以实现对象创建的封装和扩展性。文章通过日志记录器的实例,展示了工厂方法模式的结构、角色、时序图、代码实现、优点、缺点以及适用环境,并探讨了如何通过配置文件和Java反射机制实现工厂的动态创建。
【二】设计模式~~~创建型模式~~~工厂方法模式(Java)
|
2月前
|
JSON Java UED
uniapp:使用DCloud的uni-push推送消息通知(在线模式)java实现
以上展示了使用Java结合DCloud的uni-push进行在线消息推送的基本步骤和实现方法。实际部署时,可能需要依据实际项目的规模,业务场景及用户基数进行必要的调整和优化,确保消息推送机制在保证用户体验的同时也满足业务需求。
179 0
|
Java
java之wait()、notify()实现非阻塞的生产者和消费者
java之wait()、notify()实现非阻塞的生产者和消费者
238 0
|
Java 存储
用JAVA 实现“生产者-消费者”问题
生产者和消费者问题是从操作系统中的许多实际同步问题中抽象出来的具有 代表性的问题。它反映了操作系统中典型的同步例子。   生产者进程(进程由多个线程组成)生产信息,例如它可以是计算进程。消费 者进程使用信息,它可以是输出打印进程。
817 0
|
11天前
|
安全 Java 测试技术
Java并行流陷阱:为什么指定线程池可能是个坏主意
本文探讨了Java并行流的使用陷阱,尤其是指定线程池的问题。文章分析了并行流的设计思想,指出了指定线程池的弊端,并提供了使用CompletableFuture等替代方案。同时,介绍了Parallel Collector库在处理阻塞任务时的优势和特点。
|
7天前
|
安全 Java 开发者
深入解读JAVA多线程:wait()、notify()、notifyAll()的奥秘
在Java多线程编程中,`wait()`、`notify()`和`notifyAll()`方法是实现线程间通信和同步的关键机制。这些方法定义在`java.lang.Object`类中,每个Java对象都可以作为线程间通信的媒介。本文将详细解析这三个方法的使用方法和最佳实践,帮助开发者更高效地进行多线程编程。 示例代码展示了如何在同步方法中使用这些方法,确保线程安全和高效的通信。
27 9