生产者消费者的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)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在 ...
随机推荐
- MVP框架 – Ted Mosby的软件架构
作者:Hannes Dorfmann 原文链接 : Ted Mosby – Software Architect 文章出自 : Android开发技术前线 译者 : Mr.Simple 我给这篇关于A ...
- Android输入控件详解
输入控件 输入控件是您的应用用户界面中的交互式组件.Android 提供了多种可在 UI 中使用的控件,如按钮.文本字段.定位栏.复选框.缩放按钮.切换按钮等. 向 UI 中添加输入控件与向 XML ...
- GirlFriendNotFoundException异常是怎样处理的?
GirlFriendNotFoundException异常是怎样处理的? 如果说要去创造这个异常,那么我们的JAVA程序里,肯定是继承Exception去处理,所有我们可以先实现一个自己的Except ...
- FORM调用FORM(标准调客户化&客户化调标准)并执行查询的实现研究
一.先来个比较简单的,标准FORM调用客户话FORM并执行查询 1.修改CUSTOM.PLL,使用 fnd_function.execute实现打开和传递参数 参考例子如下 PROCEDURE eve ...
- EBS系统管理常用SQL语句整理汇总(参考网上资料&其他人博客)
--1查找系统用户基本信息 SELECT user_id, user_name, description, employeE_id, person_party_id FROM fnd_user; -- ...
- Android 高级控件(七)——RecyclerView的方方面面
Android 高级控件(七)--RecyclerView的方方面面 RecyclerView出来很长时间了,相信大家都已经比较了解了,这里我把知识梳理一下,其实你把他看成一个升级版的ListView ...
- Dynamics CRM2013 停用默认公共视图
CRM视图中一般只会有一个默认公共视图,如果你不想用已有的默认视图只需新建个视图再指定默认,然后将原有视图停用即可,但我碰到了个另类的问题,即在一个实体下同时存在两个默认视图而且无法停用. 如下图中的 ...
- windows平台下 c/c++进行http通信的教训
由于需要使用c++开发一个桌面应用软件,需要用到http请求进行通讯,也是本人第一次进行网络相关的开发工作,遇到了不少坑. 由于是在windows下开发和使用的应用软件,自然而然想到了调用Window ...
- Android之获取屏幕的尺寸像素及获取状态栏标题栏高度
在Android的实际开发中,会经常用到获取屏幕的尺寸的问题,以便设置一些布局在屏幕上的固定位置,从而适配各个屏幕的设备. 今天我就来讲一下怎么得到当前设备的屏幕像素吧: 一.在Activity中: ...
- 关于weak
#define DECLARE_WEAK_SELF __typeof(&*self) __weak weakSelf = self #define DECLARE_STRONG_SELF __ ...