如何进行ThreadPoolExecutor的keepAliveTime=0说明,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
上图来自《并发编程的艺术》一书,书中有下面一段描述:
““当线程池中的线程数大于corePoolSize时,keepAliveTime 为多余的空闲线程等待新任务的最长时间, 超过这个时间后多余的线程将被终止。这里把keepAliveTime设置为0L,意味着多余 的空闲线程会被立即终止。”
网上很多资料都是说的0表示在空闲的时候线程永久存活。其实是不准确的。
附上验证代码:
public static void main(String[] args) throws InterruptedException { // 创建了一个线程池 ThreadPoolExecutor executor = new ThreadPoolExecutor(1, 2, 0, TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>(1)); for (int i = 0; i < 3; i++) { executor.execute(new DemoTask(i)); } while (true) { System.out.println("总线程数:" + executor.getPoolSize() + ", 当前活跃线程数:" + executor.getActiveCount()); TimeUnit.SECONDS.sleep(1); } } static class DemoTask implements Runnable { int num; public DemoTask(int i) { this.num = i; } @Override public void run() { System.out.println("num=" + num + " Thread = " + Thread.currentThread().getName()); if (num >= 1) { try { TimeUnit.SECONDS.sleep(1); System.out.println("num=" + num + " sleep 1 s结束"); } catch (InterruptedException e) { e.printStackTrace(); } } else { try { TimeUnit.SECONDS.sleep(3); System.out.println("num=" + num + " sleep 3 s结束"); } catch (InterruptedException e) { e.printStackTrace(); } } } }
打印结果:
num=2 Thread = pool-1-thread-2总线程数:2, 当前活跃线程数:2num=0 Thread = pool-1-thread-1num=2 sleep 1 s结束num=1 Thread = pool-1-thread-2总线程数:2, 当前活跃线程数:2num=1 sleep 1 s结束总线程数:1, 当前活跃线程数:1num=0 sleep 3 s结束总线程数:1, 当前活跃线程数:1总线程数:1, 当前活跃线程数:0总线程数:1, 当前活跃线程数:0
关于如何进行ThreadPoolExecutor的keepAliveTime=0说明问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/yunloveyiyi/blog/4475018