关于java:Java面试当任务数超过线程池的核心线程数时如何让它不进入队列而是直接启用最大线程数

40次阅读

共计 687 个字符,预计需要花费 2 分钟才能阅读完成。

你们晓得,“当工作数超过线程池的外围线程数时,如何让它不进入队列,而是间接启用最大线程数”吗?

大家好,我是 Mic,一个工作了 14 年的 Java 程序员。

刚刚这个问题是一个工作 5 年的粉丝最近去某互联网公司面试遇到的。

对于这个问题,我把高手的答复整顿到了一个 15W 字的面试文档外面。

大家能够私信我支付

上面看看高手的答复

高手

当咱们提交一个工作到线程池的时候,它的工作原理分为四步。

  • 第一步,预热外围线程
  • 第二步,把工作增加到阻塞队列
  • 第三步,如果增加到阻塞队列失败,则创立非核心线程减少解决效率
  • 第四步,如果非核心线程数达到了阈值,就触发回绝策略

所以,如果心愿这个工作不进入队列,那么只须要去影响第二步的执行逻辑就行了。

Java 中线程池提供的构造方法外面,有一个参数能够批改阻塞队列的类型。

其中,就有一个阻塞队列叫 SynchronousQueue,这个队列不能存储任何元素。

它的个性是,每生产一个工作,就必须要指派一个消费者来解决,否则就会阻塞生产者。

基于这个个性,只有把线程池的阻塞队列替换成 SynchronousQueue。

就可能防止工作进入到阻塞队列,而是间接启动最大线程数去解决这个工作。

总结

这个问题考查的角度其实挺有意思。

它能筛选掉很多靠背面试题去筹备面试的同学。

凡是你理解过线程池的工作原理以及浏览过源码你都能轻易的答复进去。

大家记得点赞珍藏加关注!!!

版权申明:本博客所有文章除特地申明外,均采纳 CC BY-NC-SA 4.0 许可协定。转载请注明来自 Mic 带你学架构
如果本篇文章对您有帮忙,还请帮忙点个关注和赞,您的保持是我一直创作的能源。欢送关注同名微信公众号获取更多技术干货!

正文完
 0