Java 管程解决生产者消费者问题
同样是实验存档。//。。
依然以生产者消费者问题作为背景。
管程(=“资源管理程序”)将资源和对资源的操作封装起来,资源使用者通过接口操作资源就ok,不用去考虑进程同步的问题。
管程:
- package entity.producerconsumer;
- public class Monition {
- private Buffer buffer;
- public Monition(int bufferSize) {
- buffer = new Buffer(bufferSize);
- }
- /**
- * 如果放入产品成功返回 true
- * @return
- */
- public synchronized boolean put() {
- if (buffer.notFull()) {
- buffer.putItem();
- return true;
- }
- return false;
- }
- /**
- * 如果取出产品成功返回 true
- * @return
- */
- public synchronized boolean get() {
- if (buffer.notEmpty()) {
- buffer.getItem();
- return true;
- }
- return false;
- }
- public String getStatus() {
- return "" + buffer;
- }
- }
生产者 & 消费者:
- package entity.producerconsumer;
- public class Produc implements Runnable {
- /**
- * 统计生产者数量
- */
- private static int total = 0;
- /**
- * 生产者个体的 id
- */
- private int id;
- private Monition PC;
- public Produc(Monition monition) {
- id = ++total;
- PC = monition;
- }
- @Override
- public void run() {
- while (true) {
- if (PC.put()) {
- // 如果操作成功打印缓冲区状态
- System.out.println(id + " 号生产者: " + PC.getStatus());
- }
- }
- }
- }
/
- package entity.producerconsumer;
- public class Consu implements Runnable {
- /**
- * 统计消费者数量
- */
- private static int total = 0;
- /**
- * 消费者个体的 id
- */
- private int id;
- private Monition PC;
- public Consu(Monition monition) {
- id = ++total;
- PC = monition;
- }
- @Override
- public void run() {
- while (true) {
- if (PC.get()) {
- // 如果操作成功打印缓冲区状态
- System.out.println(id + " 号消费者: " + PC.getStatus());
- }
- }
- }
- }
/
测试:
- package test;
- import entity.producerconsumer.Consu;
- import entity.producerconsumer.Monition;
- import entity.producerconsumer.Produc;
- public class MonitionTest {
- public static void main(String[] args) {
- Monition PC = new Monition(10);
- // 创建 5 个生产者和 5 个消费者
- for (int i = 0; i != 5; ++i) {
- new Thread(new Produc(PC)).start();
- new Thread(new Consu(PC)).start();
- }
- }
- }
Java 管程解决生产者消费者问题的更多相关文章
- Java管程解决生产者消费者问题
同样是实验存档.//.. 依然以生产者消费者问题作为背景. 管程(=“资源管理程序”)将资源和对资源的操作封装起来,资源使用者通过接口操作资源就ok,不用去考虑进程同步的问题. 管程: package ...
- java多线程解决生产者消费者问题
import java.util.ArrayList; import java.util.List; /** * Created by ccc on 16-4-27. */ public class ...
- Java如何使用线程解决生产者消费者问题?
在Java编程中,如何使用线程解决生产者消费者问题? 以下示例演示如何使用线程解决生产者消费者问题. package com.yiibai; public class ProducerConsumer ...
- 使用Java的BlockingQueue实现生产者-消费者
http://tonl.iteye.com/blog/1936391 使用Java的BlockingQueue实现生产者-消费者 博客分类: Java JavaBlockingQueue阻塞队列 B ...
- Linux多线程实践(六)使用Posix条件变量解决生产者消费者问题
前面的一片文章我们已经讲过使用信号量解决生产者消费者问题.那么什么情况下我们须要引入条件变量呢? 这里借用 http://www.cnblogs.com/ngnetboy/p/3521547.htm ...
- 基于java callable及future接口解决生产者消费者问题
这两天复习java线程时,把java里面的线程基本知识点与jdk1.5以后新添加的一些类的使用都了解了一下,借用生产者消费者的问题来将他们实践一下. 题目:(题目在csdn一大牛的空间找的) 生产者- ...
- java使用synchronized与Semaphore解决生产者消费者问题对比
一.synchronized与信号量Semaphore简介 1.synchronized是java中的关键字,是用来控制线程同步的问题最常用的方法. 2.Semaphore是属于java的一个类,同样 ...
- java信号量PV操作 解决生产者-消费者问题
package test1; /** * 该例子演示生产者和消费者的问题(设只有一个缓存空间.一个消费者和一个生产者) * MySystem类定义了缓冲区个数以及信号量 * @author HYY * ...
- JAVA多线程经典问题 -- 生产者 消费者
工作2年多来一直也没有计划写自己的技术博客,最近辞职在家翻看<thingking in JAVA>,偶尔看到了生产者与消费者的一个经典的多线程同步问题.本人在工作中很少使用到多线程以及高并 ...
随机推荐
- npoi导入导出
NPOI是指构建在POI 3.x版本之上的一个程序,NPOI可以在没有安装Office的情况下对Word或Excel文档进行读写操作. NPOI是一个开源的Java读写Excel.WORD等微软OLE ...
- LINQ学习系列-----2.2 迭代器
在学习本篇迭代器之前,强烈建议可以先学习一位具有工匠精神博主的文章,链接如下: 农码一生---先说IEnumerable,我们每天用的foreach你真的懂它吗? 本篇文章,是在该博主博文的基础上再次 ...
- 安装apache
1.安装依赖软件 pcre gcc expat apr(Apache portable Run-time libraries,Apache可移植运行库) apr-util [root@localhos ...
- Service 之间如何通信?- 每天5分钟玩转 Docker 容器技术(101)
微服务架构的应用由若干 service 组成.比如有运行 httpd 的 web 前端,有提供缓存的 memcached,有存放数据的 mysql,每一层都是 swarm 的一个 service,每个 ...
- Pyhton函数篇(一)之函数中的形参与实参
1:什么是函数 函数其实就是带名字的代码块,用于完成一些具体的工作.如果我们在写一段程序的时候,需要多次用到同样的一个功能,如果每次都要重复写相同的代码,不仅会增加我们的代码量,更会让我们写出的代码让 ...
- 工厂模式(Factory Method)
1.工厂方法模式(Factory Method) 工厂方法模式分为三种: 1-1.普通工厂模式,就是建立一个工厂类,对实现了同一接口的一些类进行实例的创建. 举例如下:(我们举一个发送邮件和短信的例子 ...
- 河南省第八届ACM省赛---引水工程
引水工程 时间限制:2000 ms | 内存限制:65535 KB 难度: 描述 南水北调工程是优化水资源配置.促进区域协调发展的基础性工程,是新中国成立以来投资额最大.涉及面最广的战略性工程,事 ...
- Filebeat轻量级日志采集工具
Beats 平台集合了多种单一用途数据采集器.这些采集器安装后可用作轻量型代理,从成百上千或成千上万台机器向 Logstash 或 Elasticsearch 发送数据. 一.架构图 此次试验基于前几 ...
- 分享一些JAVA相关资源
前言 以前在学习JAVA时,因为搜索相关资源过于不便,所以在搜集了一些好用的资源之后,将此分享. 文档主要包括面试文档, JAVA的技术文档(如JAVA并发实战.设计模式之类),LINUX的相关文档以 ...
- onload和ready的区别
onload和ready的区别 1.执行时间 window.onload必须等到页面内包括图片的所有元素加载完毕后才能执行 $(document).read()是DOM结构绘制完毕后就执行,不必等到加 ...