生产者消费者的java实现
先看最简单的,也就是缓冲区的容量为1
缓冲区容量为1
import java.util.List;
public class ProducerAndConsumer2 {
static class AddThread implements Runnable {
Plate plate;
public AddThread(Plate p) {
this.plate = p;
}
@Override
public void run() {
// TODO Auto-generated method stub
plate.put(new Object());
}
}
static class GetThread implements Runnable {
Plate plate;
public GetThread(Plate p) {
this.plate = p;
}
@Override
public void run() {
// TODO Auto-generated method stub
plate.get();
}
}
static class Plate {
private List<Object> egg = new ArrayList<Object>();
public synchronized void put(Object o) {
while (egg.size() > 0) {
try {
System.out.println(
"此时盘子里有鸡蛋 生产线程"+Thread.currentThread().getName()+"阻塞");
this.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
egg.add(0, o);
System.out.println("生产线程放入一个鸡蛋");
this.notifyAll();
}
public synchronized Object get() {
while (egg.size() == 0) {
try {
System.out.println(
"此时盘子里没有鸡蛋 消费线程"+Thread.currentThread().getName()+"阻塞");
this.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
Object object = egg.get(0);
egg.clear();
System.out.println("消费线程取得一个鸡蛋");
this.notifyAll();
return object;
}
}
public static void main(String[] args) {
Plate p = new Plate();
for (int i = 0; i < 10; i++)
new Thread(new GetThread(p)).start();
for (int i = 0; i < 10; i++)
new Thread(new AddThread(p)).start();
}
}
如果盘子里可以存放多个鸡蛋就这样:
缓冲器容量大于1
import java.util.ArrayList;
import java.util.List;
public class ProducerAndConsumer {
public static void main(String[] args) {
Plate p = new Plate();
for (int i = 0; i < 10; i++)
new Thread(new GetThread(p)).start();
for (int i = 0; i < 10; i++)
new Thread(new AddThread(p)).start();
}
}
class AddThread implements Runnable {
Plate plate;
public AddThread(Plate p) {
this.plate = p;
}
@Override
public void run() {
// TODO Auto-generated method stub
plate.put(new Object());
}
}
class GetThread implements Runnable {
Plate plate;
public GetThread(Plate p) {
this.plate = p;
}
@Override
public void run() {
// TODO Auto-generated method stub
plate.get();
}
}
class Plate {
private List<Object> egg = new ArrayList<Object>(10);
//在0-9这十个空间存储鸡蛋
public synchronized void put(Object o) {
while (egg.size()==10) { //最多有是个鸡蛋
try {
System.out.println(
"此时盘子里有鸡蛋 生产线程"+Thread.currentThread().getName()+"阻塞");
this.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
egg.add(o);
System.out.println("生产线程放入一个鸡蛋 现有鸡蛋"+egg.size()+"个");
this.notifyAll();
}
public synchronized Object get() {
while (egg.size()==0) {
try {
System.out.println(
"此时盘子里没有鸡蛋 消费线程"+Thread.currentThread().getName()+"阻塞");
this.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
Object object=egg.get(egg.size()-1);
egg.remove(egg.size()-1)
this.notifyAll();
System.out.println("消费线程取得一个鸡蛋 还剩余鸡蛋"+egg.size()+"个");
return object;
}
}
关于线程通信还有一个似乎是空中网的面试题
地址如下
http://blog.csdn.net/dlf123321/article/details/42751405
感谢glt
参考资料
http://blog.csdn.net/ghsau/article/details/7433673
http://blog.csdn.net/monkey_d_meng/article/details/6251879
生产者消费者的java实现的更多相关文章
- 生产者消费者问题Java三种实现
生产者-消费者Java实现 2017-07-27 1 概述 生产者消费者问题是多线程的一个经典问题,它描述是有一块缓冲区作为仓库,生产者可以将产品放入仓库,消费者则可以从仓库中取走产品. 解决生产者/ ...
- 生产者消费者模式-Java实现
感知阶段 随着软件业的发展,互联网用户的日渐增多,并发这门艺术的兴起似乎是那么合情合理.每日PV十多亿的淘宝,处理并发的手段可谓是业界一流.用户访问淘宝首页的平均等待时间只有区区几秒,但是服务器所处理 ...
- 生产者消费者模型Java实现
生产者消费者模型 生产者消费者模型可以描述为: ①生产者持续生产,直到仓库放满产品,则停止生产进入等待状态:仓库不满后继续生产: ②消费者持续消费,直到仓库空,则停止消费进入等待状态:仓库不空后,继续 ...
- 生产者消费者模型java
马士兵老师的生产者消费者模型,我感觉理解了生产者消费者模型,基本懂了一半多线程. public class ProducerConsumer { public static void main(Str ...
- 生产者消费者模型-Java代码实现
什么是生产者-消费者模式 比如有两个进程A和B,它们共享一个固定大小的缓冲区,A进程产生数据放入缓冲区,B进程从缓冲区中取出数据进行计算,那么这里其实就是一个生产者和消费者的模式,A相当于生产者,B相 ...
- JAVA多线程之生产者 消费者模式 妈妈做面包案例
创建四个类 1.面包类 锅里只可以放10个面包 ---装面包的容器2.厨房 kitchen 生产面包 和消费面包 最多生产100个面包3.生产者4消费者5.测试类 多线程经典案例 import ja ...
- 第23章 java线程通信——生产者/消费者模型案例
第23章 java线程通信--生产者/消费者模型案例 1.案例: package com.rocco; /** * 生产者消费者问题,涉及到几个类 * 第一,这个问题本身就是一个类,即主类 * 第二, ...
- Java里的生产者-消费者模型(Producer and Consumer Pattern in Java)
生产者-消费者模型是多线程问题里面的经典问题,也是面试的常见问题.有如下几个常见的实现方法: 1. wait()/notify() 2. lock & condition 3. Blockin ...
- Java数据结构之队列的实现以及队列的应用之----简单生产者消费者应用
Java数据结构之---Queue队列 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在 ...
随机推荐
- java创建线程
创建一个线程 Java提供了两种创建线程方法: 通过实现Runable接口: http://blog.csdn.net/duruiqi_fx/article/details/52187275 通过继承 ...
- C++ 虚函数表 单继承
本文研究单继承情况下,c++对象的虚函数表的具体情况. 假设有两个类A,B, 其中B由A派生出来,A含有虚函数fun1,B含有虚函数fun2. 测试的代码如下: #include<iostrea ...
- Unsupported major.minor version 52.0
今天运行项目,切换一下eclipse,运行程序突然发现普通的类main()方法无法运行,报错详细信息如下: Exception in thread "main" java.lang ...
- android解析网络json数据(1)
1.首先获得url,传入URL类,利用URL的openconnection方法,获得URLConnection,去的输入流,进行操作,具体代码如下: public class NetConnectio ...
- JAVA面向对象-----构造方法
我们人出生的时候,有些人一出生之后再起名字的,但是有些人一旦出生就已经起好名字的.那么我们在java里面怎么在对象一旦创建就赋值呢? 构造方法作用 构造方法作用:对对象进行初始化. 构造函数与普通的函 ...
- 内存数据网格IMDG简介
1 简介 将内存作为首要存储介质不是什么新鲜事儿,我们身边有很多主存数据库(IMDB或MMDB)的例子.在对主存的使用上,内存数据网格(In Memory Data Grid,IMDG)与IMDB类似 ...
- 剑指Offer——美团内推+校招笔试题+知识点总结
剑指Offer--美团内推+校招笔试题+知识点总结 前言 美团9.9内推笔试.9.11校招笔试,反正就是各种虐,笔试内容如下: 知识点:图的遍历(DFS.BFS).进程间通信.二叉查找树节点的删除及中 ...
- iOS10软件崩溃 Xcode8崩溃 打印/字体等问题汇总 韩俊强的博客
每日更新关注:http://weibo.com/hanjunqiang 新浪微博!iOS开发者交流QQ群: 446310206 [1].Xcode8代码出现ubsystem: com.apple.U ...
- 剑指Offer--排序算法小结
剑指Offer--排序算法小结 前言 毕业季转眼即到,工作成为毕业季的头等大事,必须得认认真真进行知识储备,迎战笔试.电面.面试. 许久未接触排序算法了.平时偶尔接触到时自己会不假思索的百度,然后就是 ...
- Android 四种常见的线程池
引入线程池的好处 1)提升性能.创建和消耗对象费时费CPU资源 2)防止内存过度消耗.控制活动线程的数量,防止并发线程过多. 我们来看一下线程池的简单的构造 public ThreadPoolExec ...