核心线程池满后新任务是在线程池中新建一个线程还是阻塞到队列中去 |
您所在的位置:网站首页 › 多线程最大线程数满了怎么处理 › 核心线程池满后新任务是在线程池中新建一个线程还是阻塞到队列中去 |
核心线程池满后新任务是在线程池中新建一个线程还是阻塞到队列中去 今天部门分享会,刚好遇到一个问题,于是就查了一下。 前提:正在运行的线程数大于corePoolSize但小于maximumPoolSize。问题如下: 当线程池中的核心线程池满后,再有新任务是在线程池中创建一个新线程还是将任务加入到阻塞到队列中? 我听到这个问题时理所当然的想应该是创建一个新的线程,但是当我查询资料后才发现不是这样的,官方注释是这样的:大致意思是: 如果运行的线程数大于corePoolSize(线程池中的核心线程数)但小于maximumPoolSize(线程池中可存在的最大线程数),那么只有在队列满时才会创建一个新的线程。 通过将corePoolSize和maximumPoolSize设置为相同的值,可以创建一个固定大小的线程池,也就是将线程池中允许存在的线程都设置为核心线程。 大家感兴趣也可以自己去看一下源码,从ThreadPoolExecutor.java中的第82行开始。 看了些回答,大致原因如下,总结一下加强记忆: 线程池中创建线程是需要获取mainlock的,也就是全局锁,全局锁的使用会影响并发效率。 所以当核心线程池满后,会将新的任务阻塞到队列中去,与创建最大线程隔离开来,起一个缓冲的作用。 引入到阻塞队列中,是为了在执行execute()方法时,尽可能的避免对全局锁的获取。 找到了其他人发的一张图,加强对创建线程的理解。原图在这里: https://blog.csdn.net/luxiaoruo/article/details/106637283 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |