消费者生产者模式(2)——用java阻塞队列实现

2024-09-03 00:48

本文主要是介绍消费者生产者模式(2)——用java阻塞队列实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    生产者——消费者模式有三个阶段的编程:

    1.使用synchronized,wait,notify(这在我博客中已经有实现了,可以找找看看)

     2.使用阻塞队列LinkedBlockingQueue(这是本小节的重点)

     3.使用非阻塞式的内存结构如ConcurrentLinkedQueue(以后补充)

     本小节所讨论的生产者消费者模式是通过一个容器来解决的。生产者和消费者彼此之间不直接通信,而通过阻塞队列来进行通信,所以生产者生产完数据之后不用等待消费者处理,直接扔给阻塞队列,消费者不找生产者要数据,而是直接从阻塞队列中获取,阻塞队列就相当于一个缓冲区,平衡了生产者和消费者的处理能力。

     这个阻塞队列就是用来给生产者和消费者解耦的。纵观大多数设计模式,都会找一个第三者出来进行解耦,如工厂模式的第三者是工厂类。

下面我就用阻塞队列LinkedBlockingQueue来实现生产者消费者模式:

import java.util.concurrent.BlockingQueue;
import java.util.concurrent.LinkedBlockingQueue;public class ProducerConsumer {public static void main(String[] args) {BlockingQueue sharedQueue = new LinkedBlockingQueue();Thread prodThread = new Thread(new Producer(sharedQueue));Thread consThread = new Thread(new Consumer(sharedQueue));prodThread.start();consThread.start();}
}class Producer implements Runnable {private final BlockingQueue sharedQueue;public Producer (BlockingQueue sharedQueue) {this.sharedQueue = sharedQueue;}@Overridepublic void run() {for(int i = 0; i < 10; i++) {try {System.out.println("Produced: "+ i);sharedQueue.put(i);} catch (InterruptedException ex) {ex.printStackTrace();}}}
}class Consumer implements Runnable {private final BlockingQueue sharedQueue;public Consumer (BlockingQueue sharedQueue) {this.sharedQueue = sharedQueue;}@Overridepublic void run() {for(int i = 0; i < 10; i++) {try {System.out.println("Consumerd: "+ i);sharedQueue.take();} catch (InterruptedException ex) {ex.printStackTrace();}}}
}
运行结果:

Produced: 0
Consumerd: 0
Produced: 1
Consumerd: 1
Produced: 2
Consumerd: 2
Produced: 3
Consumerd: 3
Produced: 4
Consumerd: 4
Produced: 5
Consumerd: 5
Produced: 6
Consumerd: 6
Produced: 7
Consumerd: 7
Produced: 8
Consumerd: 8
Produced: 9
Consumerd: 9




     

这篇关于消费者生产者模式(2)——用java阻塞队列实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1131555

相关文章

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

Redis Cluster模式配置

《RedisCluster模式配置》:本文主要介绍RedisCluster模式配置,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录分片 一、分片的本质与核心价值二、分片实现方案对比 ‌三、分片算法详解1. ‌范围分片(顺序分片)‌2. ‌哈希分片3. ‌虚

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根