Java 线程池的拒绝策略 RejectedExecutorHandler

本文深入探讨了Java线程池在任务提交过多时的四种拒绝策略:CallerRunsPolicy、AbortPolicy、DiscardPolicy和DiscardOldestPolicy,分别介绍了它们在任务无法执行时的不同处理方式。

当线程池被关闭以后,在execute()方法中提交新任务将被拒绝(线程池被关闭或线程数达到maximumPoolSize),此时会采取定义的拒绝策略。在ThreadPoolExecutor中定义了四个静态内部类,均实现了RejectedExecutorService接口,并对接口中的rejectedExecution方法给出具体实现。

一、CallerRunsPolicy

如果线程池没有被关闭,则由提交该任务的线程来执行

public static class CallerRunsPolicy implements RejectedExecutionHandler {
	public CallerRunsPolicy() { }

	public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
		if (!e.isShutdown()) {
			r.run();
		}
	}
}

二、AbortPolicy

默认的拒绝策略,直接抛出RejectedExecutionException异常。

public static class AbortPolicy implements RejectedExecutionHandler {
	public AbortPolicy() { }

	public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
		throw new RejectedExecutionException("Task " + r.toString() +
											 " rejected from " +
											 e.toString());
	}
}

三、DiscardPolicy

什么都不做,直接丢弃被拒绝的任务

public static class DiscardPolicy implements RejectedExecutionHandler {
	public DiscardPolicy() { }

	public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
	}
}

四、DiscardOldestPolicy

如果线程池没有被关闭,则丢弃队列首部的任务,提交这个新的任务

public static class DiscardOldestPolicy implements RejectedExecutionHandler {
	public DiscardOldestPolicy() { }

	public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
		if (!e.isShutdown()) {
			e.getQueue().poll();
			e.execute(r);
		}
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值