java实现生产者/消费者的三种方式
package com.wenki.thread;
import java.util.LinkedList;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class ProductAndConsume {
public static void main(String[] args) {
ProductAndConsume o = new ProductAndConsume();
// Storage storage = o.new StorageOne();
// Storage storage = o.new StorageTwo();
Storage storage = o.new StorageThree();
Consumer consumer1 = o.new Consumer(storage);
Consumer consumer2 = o.new Consumer(storage);
Producter producter1 = o.new Producter(storage);
Producter producter2 = o.new Producter(storage);
Producter producter3 = o.new Producter(storage);
consumer1.start();
consumer2.start();
producter1.start();
producter2.start();
producter3.start();
}
class Producter extends Thread{
Storage storage;
public Producter(Storage storage) {
this.storage = storage;
}
public void product(){
this.storage.product();
}
@Override
public void run() {
for(;;){
product();
}
}
}
class Consumer extends Thread{
Storage storage;
public Consumer(Storage storage){
this.storage = storage;
}
public void consume(){
this.storage.consume();
}
@Override
public void run() {
for(;;){
consume();
}
}
}
interface Storage{
int MAX_SIZE = 100;
LinkedList<Object> list = new LinkedList<Object>();
public abstract void product();
public abstract void consume();
}
//第一种方式 wait() + notify()
class StorageOne implements Storage{
@Override
public void product() {
synchronized (list) {
while(list.size() == MAX_SIZE){
try {
list.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
if(list.add(new Object())){
System.out.println("生产 ### 产品数量 : " + list.size());
//通知消费者可以继续消费
list.notifyAll();
}
try {
TimeUnit.MILLISECONDS.sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
@Override
public void consume() {
synchronized (list) {
while(list.size() == 0){
try {
list.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
if(list.remove() != null){
System.out.println("消费 ### 产品数量: " + list.size());
//通知生产者可以继续生产
list.notifyAll();
}
try {
TimeUnit.MILLISECONDS.sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
//第二种方式 await() + signal()
class StorageTwo implements Storage{
Lock lock = new ReentrantLock();
Condition fully = lock.newCondition();
Condition empty = lock.newCondition();
@Override
public void product() {
lock.lock();
try{
while(list.size() == MAX_SIZE){
fully.await();
}
if(list.add(new Object())){
System.out.println("生产 ### 产品数量 : " + list.size());
empty.signalAll();
}
TimeUnit.MILLISECONDS.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}finally {
lock.unlock();
}
}
@Override
public void consume() {
lock.lock();
try{
while(list.size() == 0){
empty.await();
}
if(list.remove() != null){
System.out.println("消费 ### 产品数量: " + list.size());
fully.signalAll();
}
TimeUnit.MILLISECONDS.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}finally{
lock.unlock();
}
}
}
//第三种 BlockingQueue 阻塞队列
class StorageThree implements Storage{
LinkedBlockingQueue<Object> list = new LinkedBlockingQueue<Object>(MAX_SIZE);
@Override
public void product() {
try {
list.put(new Object());
System.out.println("生产 ### 产品数量 : " + list.size());
TimeUnit.MILLISECONDS.sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
@Override
public void consume() {
try {
if(list.take() != null){
System.out.println("消费 ### 产品数量: " + list.size());
}
TimeUnit.MILLISECONDS.sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
java实现生产者/消费者的三种方式的更多相关文章
- java 实现md5加密的三种方式与解密
java 实现md5加密的三种方式 CreateTime--2018年5月31日15点04分 Author:Marydon 一.解密 说明:截止文章发布,Java没有实现解密,但是已有网站可以免费 ...
- java中遍历集合的三种方式
第一种遍历集合的方式:将集合变为数组 package com.lw.List; import java.util.ArrayList; import java.util.List; import ja ...
- java加载配置文件的三种方式
比如我们要加载db.properties文件 如图: 比如我们要加载source目录下的db.properties文件.就有以下几种方式 第一种是文件io流: public static void l ...
- JAVA实现Base64编码的三种方式
摘要: Javabase64编码的三种方式 有如下三种方式: 方式一:commons-codec.jar Java代码 1. String base64String="whuang12 ...
- Java通过JDBC连接数据库的三种方式!!!并对数据库实现增删改查
前言 java连接数据库完整流程为: 1,获得驱动(driver),数据库连接(url),用户名(username),密码(password)基本信息的三种方式. 2,通过获得的信息完成JDBC实现连 ...
- java实现HTTP请求的三种方式
目前JAVA实现HTTP请求的方法用的最多的有两种:一种是通过HTTPClient这种第三方的开源框架去实现.HTTPClient对HTTP的封装性比较不错,通过它基本上能够满足我们大部分的需求,Ht ...
- 【转载】java实现HTTP请求的三种方式
目前JAVA实现HTTP请求的方法用的最多的有两种:一种是通过HTTPClient这种第三方的开源框架去实现.HTTPClient对HTTP的封装性比较不错,通过它基本上能够满足我们大部分的需求,Ht ...
- Java 实现线程安全的三种方式
一个程序在运行起来的时候会转换成进程,通常含有多个线程. 通常情况下,一个进程中的比较耗时的操作(如长循环.文件上传下载.网络资源获取等),往往会采用多线程来解决. 比如显示生活中,银行取钱问题.火车 ...
- HTTP:Java实现HTTP请求的三种方式
目前JAVA实现HTTP请求的方法用的最多的有两种: 一种是通过HTTPClient这种第三方的开源框架去实现.HTTPClient对HTTP的封装性比较不错,通过它基本上能够满足我们大部分的需求,H ...
随机推荐
- hibernate懒加载导致jackjson解析json时StackOverFlow
@JsonIgnore @JsonFilter @JsonBackReference @JsonManagedReference @JsonIgnoreProperties jackson中的@Jso ...
- Mysql-5.7.21安装配置
搞开发多年,其实MySql前前后后安装配置了无数次,但是每次都需要到网上搜教程,折腾半天才搞定,这次索性把整个过程全部记录下来,以便以后查阅. 下载 到MySql官网,导航找到DOWNLOADS> ...
- C# HttpClient设置cookies的两种办法 (转发)
一般有两种办法 第一种handler.UseCookies=true(默认为true),默认的会自己带上cookies,例如 var handler = new HttpClientHandler() ...
- Python内置函数(58)——input
英文文档: input([prompt]) If the prompt argument is present, it is written to standard output without a ...
- 启动Eclipse时An internal error occurred during: "Initializing Java Tooling".错误
解决方法一 重置窗口布局: windows > perspective > reset perspective 解决方法二: 如果上述方法不好使,采用下面的这种方法: 删除workspac ...
- 【iOS】 含tableView的ViewController基类的实现
上篇博客写了ViewController的基类的实现,这篇博客主要写在BaseViewController的基础上实现一个含tableView控件的基类的实现,主要给包含tableView的页面来继承 ...
- centos7配置Apache支持HTTPS
Apache版本2.4 安装mod_ssl yum install mod_ssl 建立文件夹,存放sslkey mkdir /etc/httpd/ssl/ 建立凭证档 openssl req -x5 ...
- jupyter notebook的架构
最近项目需要改写jupyter notebook的内核,由于内功不够,英语过差,读文档真的是心痛,然后各种搜索找到了一篇不错的讲解. 转自:http://blog.just4fun.site/jupy ...
- Text-文本检查
#检查文本 from tkinter import * import hashlib master=Tk() text = Text(master,width=30,height=5) text.pa ...
- 推荐系统——online(上)
框架介绍 上一篇从总体上介绍了推荐系统,推荐系统online和offline是两个组成部分,其中offline负责数据的收集,存储,统计,模型的训练等工作:online部分负责处理用户的请求,模型数据 ...