编写一个生产者消费者模式的JAVA工程

2024-09-07 11:18

本文主要是介绍编写一个生产者消费者模式的JAVA工程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

编写一个生产者消费者模式的JAVA工程; 要求:
1)符合生产者消费者模式,避免出现资源访问冲突;
2)输出生产和消费的执行过程;
3)分别统计生产者和消费者的执行时长和等待时长(目前还不知道怎么搞,其他的参考http://blog.csdn.net/monkey_d_meng/article/details/6251879)

  1. 创建类Storage,作为仓库
import java.util.LinkedList;public class Storage {private final int MAX_SIZE=100;//仓库容量private LinkedList<Object> list = new LinkedList<Object>();//仓库存储的东西/*生产num件货物*/public void produce(int num){       synchronized(list){         //锁定list对象while(list.size()+num>MAX_SIZE){System.out.println("要生产的产品数量:"+num+"    现在的库存:"+list.size()+"    仓库不够放");try {list.wait();//由于生产条件不满足,暂停生产} catch (InterruptedException e) {e.printStackTrace();}}System.out.println("正在生产...");for (int i = 0; i < num; i++) {list.add(new Object());try {Thread.sleep(100);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}}System.out.println("已经生产的产品:"+num+"    现在的库存为:"+list.size());list.notifyAll();}}/*消费num件东西*/public void consume(int num){synchronized (list) {while (list.size() < num) {System.out.println("要消费的产品数量:"+num+"    现在的库存为:"+list.size()+"    仓库货不够消费");try {list.wait();//由于库存不够,没法消费} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}}System.out.println("正在消费...");for (int i = 0; i < num; i++) {list.remove();try {Thread.sleep(100);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}}System.out.println("已经消费的产品:"+ num + "    现在的库存为:"+list.size());list.notifyAll();}}public LinkedList<Object> getList() {return list;}public void setList(LinkedList<Object> list) {this.list = list;}public int getMAX_SIZE() {return MAX_SIZE;}}
  1. 创建类Producers,负责生产
public class Producers extends Thread{private int num;private Storage storage;public Producers(Storage storage) {this.storage = storage;}/*线程run函数*/public void run(){produce(num);}/*调用仓库类中的生产方法*/public void produce(int num) {storage.produce(num);}public int getNum() {return num;}public void setNum(int num) {this.num = num;}public Storage getStorage() {return storage;}public void setStorage(Storage storage) {this.storage = storage;}}
  1. 创建类Consumers,负责消费

public class Consumers extends Thread {private int num;private Storage storage;public Consumers(Storage storage) {this.storage = storage;}public void run(){consume(num);}/*调用仓库的消费函数*/public void consume(int num) {storage.consume(num);}public int getNum() {return num;}public void setNum(int num) {this.num = num;}public Storage getStorage() {return storage;}public void setStorage(Storage storage) {this.storage = storage;}}
  1. 测试类
/*测试类:用于显示生产者消费者的运行情况*/
public class Test {public static void main(String[] args) {Storage storage = new Storage();//构建一个公用的仓库//创建若干个生产者Producers producer1 = new Producers(storage);Producers producer2 = new Producers(storage);Producers producer3 = new Producers(storage);Producers producer4 = new Producers(storage);Producers producer5 = new Producers(storage);Producers producer6 = new Producers(storage);Producers producer7 = new Producers(storage);//创建若干个消费者Consumers consumer1 = new Consumers(storage);Consumers consumer2 = new Consumers(storage);Consumers consumer3 = new Consumers(storage);/*设置生产者生产数量*/producer1.setNum(10);producer2.setNum(10);producer3.setNum(10);producer4.setNum(10);producer5.setNum(10);producer6.setNum(10);producer7.setNum(80);/*设置消费者生产数量*/consumer1.setNum(50);consumer2.setNum(20);consumer3.setNum(30);/*启动线程*/consumer1.start();consumer2.start();consumer3.start();producer1.start();producer2.start();producer3.start();producer4.start();producer5.start();producer6.start();producer7.start();}
}

运行结果如下(每次结果都不同):

要消费的产品数量:50 现在的库存为:0 仓库货不够消费
要消费的产品数量:20 现在的库存为:0 仓库货不够消费
要消费的产品数量:30 现在的库存为:0 仓库货不够消费
正在生产…
已经生产的产品:10 现在的库存为:10
要消费的产品数量:30 现在的库存为:10 仓库货不够消费
要消费的产品数量:20 现在的库存为:10 仓库货不够消费
要消费的产品数量:50 现在的库存为:10 仓库货不够消费
正在生产…
已经生产的产品:80 现在的库存为:90
正在生产…
已经生产的产品:10 现在的库存为:100
要生产的产品数量:10 现在的库存:100 仓库不够放
要生产的产品数量:10 现在的库存:100 仓库不够放
要生产的产品数量:10 现在的库存:100 仓库不够放
要生产的产品数量:10 现在的库存:100 仓库不够放
正在消费…
已经消费的产品:50 现在的库存为:50
正在消费…
已经消费的产品:20 现在的库存为:30
正在消费…
已经消费的产品:30 现在的库存为:0
正在生产…
已经生产的产品:10 现在的库存为:10
正在生产…
已经生产的产品:10 现在的库存为:20
正在生产…
已经生产的产品:10 现在的库存为:30
正在生产…
已经生产的产品:10 现在的库存为:40

这篇关于编写一个生产者消费者模式的JAVA工程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1144912

相关文章

Java使用MethodHandle来替代反射,提高性能问题

《Java使用MethodHandle来替代反射,提高性能问题》:本文主要介绍Java使用MethodHandle来替代反射,提高性能问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录一、认识MethodHandle1、简介2、使用方式3、与反射的区别二、示例1、基本使用2、(重要)

Java实现本地缓存的常用方案介绍

《Java实现本地缓存的常用方案介绍》本地缓存的代表技术主要有HashMap,GuavaCache,Caffeine和Encahche,这篇文章主要来和大家聊聊java利用这些技术分别实现本地缓存的方... 目录本地缓存实现方式HashMapConcurrentHashMapGuava CacheCaffe

SpringBoot整合Sa-Token实现RBAC权限模型的过程解析

《SpringBoot整合Sa-Token实现RBAC权限模型的过程解析》:本文主要介绍SpringBoot整合Sa-Token实现RBAC权限模型的过程解析,本文给大家介绍的非常详细,对大家的学... 目录前言一、基础概念1.1 RBAC模型核心概念1.2 Sa-Token核心功能1.3 环境准备二、表结

eclipse如何运行springboot项目

《eclipse如何运行springboot项目》:本文主要介绍eclipse如何运行springboot项目问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目js录当在eclipse启动spring boot项目时出现问题解决办法1.通过cmd命令行2.在ecl

Java中的Closeable接口及常见问题

《Java中的Closeable接口及常见问题》Closeable是Java中的一个标记接口,用于表示可以被关闭的对象,它定义了一个标准的方法来释放对象占用的系统资源,下面给大家介绍Java中的Clo... 目录1. Closeable接口概述2. 主要用途3. 实现类4. 使用方法5. 实现自定义Clos

Jvm sandbox mock机制的实践过程

《Jvmsandboxmock机制的实践过程》:本文主要介绍Jvmsandboxmock机制的实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、背景二、定义一个损坏的钟1、 Springboot工程中创建一个Clock类2、 添加一个Controller

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、

MQTT SpringBoot整合实战教程

《MQTTSpringBoot整合实战教程》:本文主要介绍MQTTSpringBoot整合实战教程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录MQTT-SpringBoot创建简单 SpringBoot 项目导入必须依赖增加MQTT相关配置编写

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请

Spring Security介绍及配置实现代码

《SpringSecurity介绍及配置实现代码》SpringSecurity是一个功能强大的Java安全框架,它提供了全面的安全认证(Authentication)和授权(Authorizatio... 目录简介Spring Security配置配置实现代码简介Spring Security是一个功能强