使用BlockQueue实现生产者和消费者模式
数据
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | package cn.lonecloud.procum; /** * @author lonecloud * @version v1.0 * @date 上午11:00 2018/5/7 */ public class Data { private String data; public String getData() { return data; } public void setData(String data) { this .data = data; } } |
生产者
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 | package cn.lonecloud.procum; import java.util.Random; import java.util.concurrent.BlockingQueue; import java.util.concurrent.TimeUnit; import java.util.concurrent.atomic.AtomicInteger; /** * @author lonecloud * @version v1.0 * @date 上午10:58 2018/5/7 */ public class Provider implements Runnable { private BlockingQueue<Data> queue; private static AtomicInteger integer = new AtomicInteger( 0 ); public Provider(BlockingQueue<Data> queue) { this .queue = queue; } Random random = new Random(); @Override public void run() { while ( true ) { int i = random.nextInt( 1000 ); try {<br> //模拟数据耗时 Thread.sleep(i); } catch (InterruptedException e) { e.printStackTrace(); } Data data = new Data(); data.setData(String.valueOf(integer.getAndIncrement())); try { if (!queue.offer(data, 20 , TimeUnit.SECONDS)) { System.out.println( "offer error" ); } } catch (InterruptedException e) { e.printStackTrace(); } } } } |
消费者
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | package cn.lonecloud.procum; import java.util.Objects; import java.util.Random; import java.util.concurrent.BlockingQueue; import java.util.concurrent.TimeUnit; /** * @author lonecloud * @version v1.0 * @date 上午10:58 2018/5/7 */ public class Customer implements Runnable { private BlockingQueue<Data> queue; public Customer(BlockingQueue<Data> queue) { this .queue = queue; } Random random = new Random(); @Override public void run() { while ( true ) { try { Data data = queue.take(); System.out.println( "---------" +data.getData()); } catch (InterruptedException e) { e.printStackTrace(); } int i = random.nextInt( 1000 ); try { Thread.sleep(i); } catch (InterruptedException e) { e.printStackTrace(); } } } } |
主函数
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | package cn.lonecloud.procum; import cn.lonecloud.thread.factory.TraceThreadPool; import java.util.concurrent.*; /** * @author lonecloud * @version v1.0 * @date 上午11:06 2018/5/7 */ public class Main { public static void main(String[] args) { BlockingQueue queue = new ArrayBlockingQueue( 10 ); // ThreadPoolExecutor poolExecutor=new TraceThreadPool(5,5,20, TimeUnit.SECONDS,new ArrayBlockingQueue<>(10)); ExecutorService poolExecutor=Executors.newFixedThreadPool( 5 ); for ( int i = 0 ; i < 3 ; i++) { Customer customer = new Customer(queue); poolExecutor.submit(customer); } for ( int i = 0 ; i < 5 ; i++) { Provider provider = new Provider(queue); poolExecutor.submit(provider); } } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
2016-05-07 韩信点兵(hanxin)
2016-05-07 阶乘之和 输入n,计算S=1!+2!+3!+…+n!的末6位(不含前导0)。n≤10 6 ,n!表示 前n个正整数之积。
2016-05-07 对于任意大于1的自然数n,若n为奇数,则将n变为3n+1,否则变为n的一半。 经过若干次这样的变换,一定会使n变为1
2016-05-07 java 中对对象的调用
2016-05-07 static关键字的使用总结
2016-05-07 break的标签的用法
2016-05-07 Java中空串和null串的区别