原 线程池的工作原理(四)
版权声明:本文为博主原创文章,请尊重他人的劳动成果,转载请附上原文出处链接和本声明。
本文链接:https://www.91mszl.com/zhangwuji/article/details/1152
一:ThreadPoolExecutor的execute方法的执行示意图:
二:线程池的主要处理流程
总结:
(1)在创建线程池后,等待提交过来的任务请求。
(2)当调用execute()方法添加一个请求任务是,线程池会做如下判断:
(2.1)如果正在运行的线程数量小于corePoolSize,那么马上创建线程运行这个任务。
(2.2)如果正在运行的线程数量大于或等于corePoolSize,那么将这个任务放入队列。
(2.3)如果这时候队列满了,且正在运行的线程数量还小于maximumPoolSize,那么还是要创建非核心线程立刻运行这个任务。
(2.4)如果队列满了,且正在运行的线程数量大于或等于maximumPoolSize,那么线程次会启动饱和拒绝策略来执行。
(3)当一个线程完成任务是,它会从队列中取下一个任务来执行。
(4)当一个线程空闲或超过一定的时间(keepAliveTime)时,线程池会判断:如果当前运行的线程数大于corePoolSize,那么这个线程就被停掉。所以线程池的所有任务完成后,它最终会收缩到corePoolSize的大小。
2019-12-03 15:37:55 阅读(911)
名师出品,必属精品 https://www.91mszl.com
博主信息