码迷,mamicode.com
首页 > 编程语言 > 详细

线程池相关

时间:2018-12-22 13:50:45      阅读:177      评论:0      收藏:0      [点我收藏+]

标签:dex   lis   ima   try   latch   adf   实现   http   iss   

支持生产阻塞的线程池, 使用了阻塞生产者的方式. 把队列设为有限队列.队列满了,调用构造时传入的RejectedExecutionHandler去拒绝任务的处理

RejectedExecutionHandler中继续往有界队列中put(阻塞)来添加元素.

new RejectedExecutionHandler() {
	@Override
	public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
		if (!executor.isShutdown()) {
			try {
				executor.getQueue().put(r);
			} catch (InterruptedException e) {
				// should not be interrupted
			}
		}
	}
};

http://ifeve.com/blocking-threadpool-executor/

 

复习一下线程池队列满了之后的拒绝策略

一复习,拉一串.

谷歌的有个库,

 

提供了一个ThreadFactoryBuilder,可以把一些复杂的参数都写在链式里面.

ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("ABC-Pool-%d").build();

然后创建线程池

ExecutorService pool = new ThreadPoolExecutor(

3,  //3个core

200,//200个maxPoolSize

0L,//keepAlived time

TimeUnit.MILLISECONDS,  //kepAlivedTime 单位

new LinkedBlockingQueue<Runnable>(1024), //队列, 设为有界

namedThreadFactory, //线程工厂

new ThreadPoolExecutor.AbortPolicy() //拒绝策略, 是RejectedExecutionHandler 的实现

);

其中JDK实现的拒绝策略有4种

技术分享图片

AbortPolicy 的实现其实是抛出  throw new RejectedExecutionException("Task " + r.toString() +" rejected from " +e.toString());

DiscardPolicy 的实现是 什么都不做,-->悄悄的丢掉

DiscardOldestPolicy 的实现是, 悄悄的从队列里e.getQueue().poll();掉一个task, 然后把当前task加进去. --->悄悄的顶一个出去.

CallerRunsPolicy的实现是, 让生产者自己做.(生产线程就会阻塞)

 

线程池然后使用 pool.execute(runnable)来执行runnable task.

pool.execute(()->{  //do something  });

可以结合countDownLatch,来阻塞最后的终止.

 

线程池相关

标签:dex   lis   ima   try   latch   adf   实现   http   iss   

原文地址:https://www.cnblogs.com/tekikesyo/p/10160723.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!