有限BlockingQueue资源在多线程池ThreadPoolExector中的控制和处理

有时候我们需要处理类似这样的问题

1. 队列资源是有限的,一条队列里只能有10个位置,当满了后,后面来的需要等待前面的处理完有空位后再被处理。

2. 处理是多线程的,都在读这个队列


在不考滤第三方队列,单纯用JDK支持的BlockingQueue和ThreadPoolExecutor实现。可以是:

1.限制BQ的大小,每个新的item通过put放法放入BQ中,这个方法的意思是如果满了就会等空位

2.把BQ放到ThreadPoolExecutor中, 然后启动 threadPoolExecutor中的work去执行这些Runnable 

3.  需要调 用 prestartAllCoreThreads 来使线程work动作起来处理队列里的请求

下面是一个例子:

public class BlockingQueueTest {

	public static void main(String[] args) throws InterruptedException {
		BlockingQueue<Runnable> sharedQueue = new LinkedBlockingQueue<>(10); //capacity
		ThreadPoolExecutor eService =  new ThreadPoolExecutor(3, 3,
                0L, TimeUnit.MILLISECONDS,
                sharedQueue);
		eService.prestartAllCoreThreads();
		for(int i=0;i<100;i++){
			System.out.println(" before current:"+i+",queue size:"+sharedQueue.size());
			Runnable task=()->{
				try {
					Thread.sleep(10);
				} catch (Exception e) {
					e.printStackTrace();
				}
				System.out.println(" queue size:"+sharedQueue.size());
			};
			sharedQueue.put(task);
			System.out.println(" after current:"+i+",queue size:"+sharedQueue.size());
		}
		eService.shutdown();
	}

}

输出结果如果,可以看得出queue size最大就是10了,因为是用了put :

 before current:0,queue size:0
 after current:0,queue size:1
 before current:1,queue size:0
 after current:1,queue size:1
 before current:2,queue size:0
 after current:2,queue size:0
 before current:3,queue size:0
 after current:3,queue size:1
 before current:4,queue size:1
 after current:4,queue size:2
 before current:5,queue size:2
 after current:5,queue size:3
 before current:6,queue size:3
 after current:6,queue size:4
 before current:7,queue size:4
 after current:7,queue size:5
 before current:8,queue size:5
 after current:8,queue size:6
 before current:9,queue size:6
 after current:9,queue size:7
 before current:10,queue size:7
 after current:10,queue size:8
 before current:11,queue size:8
 after current:11,queue size:9
 before current:12,queue size:9
 after current:12,queue size:10
 before current:13,queue size:10
 queue size:10
 queue size:10
 after current:13,queue size:10
 before current:14,queue size:9
 after current:14,queue size:10
 before current:15,queue size:10
 queue size:10
 after current:15,queue size:10
 before current:16,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:16,queue size:10
 before current:17,queue size:8
 after current:17,queue size:9
 before current:18,queue size:9
 after current:18,queue size:10
 before current:19,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:19,queue size:10
 before current:20,queue size:8
 after current:20,queue size:9
 before current:21,queue size:9
 after current:21,queue size:10
 before current:22,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:22,queue size:9
 before current:23,queue size:8
 after current:23,queue size:9
 before current:24,queue size:9
 after current:24,queue size:10
 before current:25,queue size:10
 queue size:10
 queue size:10
 after current:25,queue size:9
 queue size:10
 before current:26,queue size:9
 after current:26,queue size:9
 before current:27,queue size:9
 after current:27,queue size:10
 before current:28,queue size:10
 queue size:10
 queue size:10
 after current:28,queue size:10
 before current:29,queue size:9
 after current:29,queue size:10
 before current:30,queue size:10
 queue size:10
 after current:30,queue size:10
 before current:31,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:31,queue size:8
 before current:32,queue size:8
 after current:32,queue size:9
 before current:33,queue size:9
 after current:33,queue size:10
 before current:34,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:34,queue size:10
 before current:35,queue size:8
 after current:35,queue size:9
 before current:36,queue size:9
 after current:36,queue size:10
 before current:37,queue size:10
 queue size:10
 queue size:10
 after current:37,queue size:9
 before current:38,queue size:9
 queue size:10
 after current:38,queue size:10
 before current:39,queue size:9
 after current:39,queue size:10
 before current:40,queue size:10
 queue size:10
 queue size:10
 after current:40,queue size:9
 before current:41,queue size:9
 after current:41,queue size:10
 before current:42,queue size:10
 queue size:10
 after current:42,queue size:10
 before current:43,queue size:10
 queue size:10
 queue size:10
 after current:43,queue size:10
 before current:44,queue size:9
 after current:44,queue size:10
 before current:45,queue size:10
 queue size:10
 after current:45,queue size:10
 before current:46,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:46,queue size:10
 before current:47,queue size:8
 after current:47,queue size:9
 before current:48,queue size:9
 after current:48,queue size:10
 before current:49,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:49,queue size:10
 before current:50,queue size:8
 after current:50,queue size:9
 before current:51,queue size:9
 after current:51,queue size:10
 before current:52,queue size:10
 queue size:10
 queue size:10
 after current:52,queue size:10
 before current:53,queue size:9
 queue size:10
 after current:53,queue size:10
 before current:54,queue size:9
 after current:54,queue size:10
 before current:55,queue size:10
 queue size:10
 queue size:9
 queue size:9
 after current:55,queue size:8
 before current:56,queue size:8
 after current:56,queue size:9
 before current:57,queue size:9
 after current:57,queue size:10
 before current:58,queue size:10
 queue size:10
 queue size:10
 after current:58,queue size:9
 before current:59,queue size:9
 after current:59,queue size:10
 before current:60,queue size:10
 queue size:10
 after current:60,queue size:10
 before current:61,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:61,queue size:10
 before current:62,queue size:8
 after current:62,queue size:9
 before current:63,queue size:9
 after current:63,queue size:10
 before current:64,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:64,queue size:10
 before current:65,queue size:8
 after current:65,queue size:9
 before current:66,queue size:9
 after current:66,queue size:10
 before current:67,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:67,queue size:9
 before current:68,queue size:8
 after current:68,queue size:9
 before current:69,queue size:9
 after current:69,queue size:10
 before current:70,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:70,queue size:9
 before current:71,queue size:8
 after current:71,queue size:9
 before current:72,queue size:9
 after current:72,queue size:10
 before current:73,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:73,queue size:10
 before current:74,queue size:8
 after current:74,queue size:9
 before current:75,queue size:9
 after current:75,queue size:10
 before current:76,queue size:10
 queue size:10
 queue size:10
 after current:76,queue size:10
 before current:77,queue size:9
 queue size:10
 after current:77,queue size:10
 before current:78,queue size:9
 after current:78,queue size:10
 before current:79,queue size:10
 queue size:10
 queue size:10
 after current:79,queue size:10
 before current:80,queue size:9
 queue size:10
 after current:80,queue size:10
 before current:81,queue size:9
 after current:81,queue size:10
 before current:82,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:82,queue size:10
 before current:83,queue size:8
 after current:83,queue size:9
 before current:84,queue size:9
 after current:84,queue size:10
 before current:85,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:85,queue size:9
 before current:86,queue size:8
 after current:86,queue size:9
 before current:87,queue size:9
 after current:87,queue size:10
 before current:88,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:88,queue size:10
 before current:89,queue size:8
 after current:89,queue size:9
 before current:90,queue size:9
 after current:90,queue size:10
 before current:91,queue size:10
 queue size:10
 queue size:10
 after current:91,queue size:9
 before current:92,queue size:9
 after current:92,queue size:10
 before current:93,queue size:10
 queue size:10
 after current:93,queue size:10
 before current:94,queue size:10
 queue size:10
 queue size:10
 queue size:10
 after current:94,queue size:10
 before current:95,queue size:8
 after current:95,queue size:9
 before current:96,queue size:9
 after current:96,queue size:10
 before current:97,queue size:10
 queue size:10
 queue size:9
 queue size:8
 after current:97,queue size:8
 before current:98,queue size:8
 after current:98,queue size:9
 before current:99,queue size:9
 after current:99,queue size:10
 queue size:10
 queue size:10
 queue size:8
 queue size:7
 queue size:7
 queue size:5
 queue size:4
 queue size:4
 queue size:2
 queue size:1
 queue size:1
 queue size:0
 queue size:0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值