当前位置:网站首页>ThreadPoolExecutor的keepAliveTime=0说明
ThreadPoolExecutor的keepAliveTime=0说明
2022-07-20 09:41:00 【全栈程序员站长】
大家好,又见面了,我是全栈君。
如题,如下图,解释 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, 当前活跃线程数:2
num=0 Thread = pool-1-thread-1
num=2 sleep 1 s结束
num=1 Thread = pool-1-thread-2
总线程数:2, 当前活跃线程数:2
nu
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/120971.html原文链接:https://javaforall.cn
边栏推荐
猜你喜欢
随机推荐
Cloud foundry development 4 CF command
DLL load failed: 页面文件太小,无法完成操作
9 redis stress test redis benchmark
look out! A "pit" matched by regular test()
Redis-SortSet类型
数商云:如何实现供应商SRM管理系统的应用价值?
MATLAB画雷达图(四行代码)
File文件改名字
centos 安装mysql
Construction scheme of smart mine digital twin management system
SQL语句问题,不知道是否正确,求指导
Kettle【实践 05】Kettle处理JSON格式数据的4种方法及适用场景和优劣分析(云资源分享:json数据+ktr)
UDP 的报文结构和注意事项
[postgraduate entrance examination vocabulary training camp] day 8 - complete, traditional, extra, aford, professional, required
Redis-命令行客户端
What is stack?
Usage of mappartitions in pyspark
Network architecture in Skynet
C语言编译预处理详情以及宏和函数的对比
Stm32+dht11 reading temperature and humidity data display