线程池

为什么要用线程池

  1. 线程的创建和销毁需要消耗资源 (重复利用线程,减少创建和销毁的次数)
  2. 任务到来时,需要等待线程的创建。(提高响应速度)
  3. 如果无限制地创建,会造成系统的不稳定性。(提高线程的可管理性)

工作原理

当一个任务提交过来到线程池,线程池的处理如下:

  1. 如果正在执行任务的核心线程小于最大的核心线程数量(corePoolSize),则再创建新线程;(获取全局锁)
  2. 假如核心线程大于等于核心线程数量,加入BlockingQueue
  3. 如果BlockingQueue满了,而且没有达到线程池的最大容量(maximumPoolSize),则创建新线程执行任务(获取全局锁)
  4. 如果 BlockingQueue满了,但是如果创建新线程超出maximumPoolSize,任务被拒绝
  • keepAliveTime:表示线程没有任务执行时最多保持多久时间会终止。默认情况下,只有当线程池中的线程数大于corePoolSize时,keepAliveTime才会起作用,直到线程池中的线程数不大于corePoolSize,即当线程池中的线程数大于corePoolSize时,如果一个线程空闲的时间达到keepAliveTime,则会终止,直到线程池中的线程数不超过corePoolSize。但是如果调用了allowCoreThreadTimeOut(boolean)方法,在线程池中的线程数不大于corePoolSize时,keepAliveTime参数也会起作用,直到线程池中的线程数为0;

参考

理解ThreadPoolExecutor源码(一)线程池的corePoolSize、maximumPoolSize和poolSize
深入理解Java之线程池

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 阿呆的项目经理给阿呆分配了一个统计点击量的问题。情景是这样的:每个广告位上的创意都可以点击,点击过后会经过服务器跳...
    等风的猪_阅读 3,926评论 0 3
  • 原文连接 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发...
    zjk_00阅读 3,785评论 0 1
  • 转自http://www.cnblogs.com/dolphin0520/p/3932921.html Java并...
    Allen_cyn阅读 5,882评论 0 4
  • 我常常会梦到一个相同的场景:在一个空气清晰的早晨,独自一人漫步在长满绿草的山坡上,内心恬静而孤独。忽然看见...
    Joyce_64c9阅读 2,444评论 0 0
  • 10-8 老家 雨 早上起床,感觉自己突然长大了一般,直接晋升为一家之长的感觉。 起床后,接着和慧妹一起下楼,走...
    旦旦日记阅读 968评论 0 1