【面试题】你知道如果线程池的队列满了之后,会发生什么事情吗?

线程池的核心参数如corePoolSize、maximumPoolSize和队列类型(如ArrayBlockingQueue)对系统性能至关重要。有界队列能防止内存溢出,而无界队列可能导致OOM或高CPU负载。合理设置最大线程数避免任务拒绝,自定义拒绝策略可将任务持久化,待系统负载降低后再执行。实际应用中需根据业务负载和压测数据调整参数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本问题主要考察线程池工作原理

有界队列,可以避免内存溢出

【corePoolSize】核心线程数设置为10

【maximumPoolSize】最大线程数,设置为Integer.MAX_VALUE 21亿

【queue】队列设置为有界队列ArrayBlockQueue(200)

如果瞬间任务特别多,你可以无限制的不停地创建额外的线程出来,一台机器上可能有很多很多很多线程,每个线程都有自己的栈内存,占用一定的内存资源,会导致内存资源耗尽,系统也会崩溃。

即使内存没有崩溃,也会导致机器的cpu load(cpu负载)特别高。

假设【maximumPoolSize】最大线程数,设置为200。可能会导致任务被拒绝掉,很多任务无法被执行。

无界队列用的比较多,实际情况下得看系统业务的具体负载。具体情况具体分析

可以自定义一个拒绝策略:

自定义一个reject策略,如果线程池无法执行更多的任务了,此时建议你可以把这个任务信息持久化写入磁盘里去,后台专门启动一个线程,后续等待你的线程池的工作负载降低了,他可以慢慢的从磁盘里读取之前持久化的任务,重新提交到线程池里去执行

【评论区】

1、8核16G的内存 一般可以创建多少线程呢?

根据你的业务场景来去设计,核心线程数=CPU核数*(执行时间/(执行时间+等待时间))

执行时间:代码中运算

等待时间:比如调用dubbo接口等待响应

2、如果使用无界队列,那么可能会导致OOM甚至宕机。 如果使用有界队列,然后设置max线程数=max那么会导致创建很多线程,也可能导致服务器崩溃。 所以要根据具体的场景以及具体的压测数据,来设定这些参数。最后就是我们可以手动去实现一个拒绝策略,将请求持久化一下,然后后台线程去等线程池负载降下来了后再读出来继续执行。

回答:Java线程池是Java中的一个重点知识,并且在Java的工作中经常会遇到,因此在面试中也是必问的面试题目。以下是一些常见的Java线程池面试题: 1. 谈谈什么是线程池? 2. 为什么要使用线程池? 3. 你们哪些地方会使用到线程池? 4. 线程池有哪些作用? 5. 线程池的创建方式有哪些? 6. 线程池底层是如何实现复用的? 7. ThreadPoolExecutor核心参数有哪些? 8. 线程池创建的线程会一直在运行状态吗? 9. 为什么阿里巴巴不建议使用Executors? 10. 线程池的底层实现原理是什么? 11. 线程池队列满了,任务会丢失吗? 12. 线程池的拒绝策略类型有哪些? 13. 线程池如何合理配置参数? 这些问题涵盖了线程池的基本概念、使用场景、实现原理以及相关的配置和策略等方面的知识。了解这些问题能够帮助面试者更好地理解和应用Java线程池。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [java线程池面试题有哪些?java线程池常见面试题](https://blog.csdn.net/muli525/article/details/123553744)[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^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [(一)【Java精选面试题线程池底层实现原理(含答案)](https://blog.csdn.net/qq_30999361/article/details/124924343)[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^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值