java 线程池拒绝策略
时间: 2023-10-26 21:37:18 浏览: 47
Java线程池拒绝策略是指在线程池无法接受新的任务时,采取的处理方式。主要有四种拒绝策略:
1. AbortPolicy(默认策略):直接抛出RejectedExecutionException异常,不执行新任务。
2. CallerRunsPolicy:直接在调用者线程中执行新任务,即主线程中执行任务。
3. DiscardOldestPolicy:将等待队列中最早的任务移除,然后将新任务添加到队列尾部。
4. DiscardPolicy:直接丢弃新任务,不作处理。
需要注意的是,如果任务数超出了线程池的处理能力,一定要及时调整线程池参数或者采用合适的拒绝策略,否则会导致CPU繁忙,造成系统崩溃等问题。
相关问题
java线程池拒绝策略new ThreadPoolExecutor.CallerRunsPolicy()
Java线程池中的拒绝策略是指当任务队列已满并且线程池中的线程已经达到最大数量时,新的任务无法继续提交时所采取的策略。在这种情况下,拒绝策略将决定如何处理这些无法处理的任务。
ThreadPoolExecutor类中有四种拒绝策略可供选择,其中一种是CallerRunsPolicy。这个策略会直接在提交任务的线程中运行该任务,也就是说,如果任务无法被线程池接受,它将在提交任务的线程中运行,由提交任务的线程来执行该任务。
这种拒绝策略的优点在于,它可以保证所有的任务都能被执行,因为最终都会由提交任务的线程来执行。但是它也有缺点,因为如果线程池不能接受新任务,那么提交任务的线程必须等待之前提交的任务完成后才能执行新的任务,这可能会导致提交任务的线程被阻塞。
java线程池的拒绝策略
Java线程池提供了四种拒绝策略。默认的拒绝策略是拒绝任务并抛出异常,可以通过设置`RejectedExecutionHandler`参数来实现该策略。例如,可以使用`ThreadPoolExecutor.AbortPolicy()`来设置默认的拒绝策略。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* [Java 线程池四种拒绝策略](https://blog.csdn.net/qq_42700121/article/details/124442422)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *3* [java线程池拒绝策略详解](https://blog.csdn.net/guangyingposuo/article/details/106253140)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]