newCachedThreadPool线程池的使用

本文深入解析了newCachedThreadPool的工作原理,对比newFixedThreadPool,强调其动态调整线程池大小的能力,节省资源的同时确保高效率。通过示例代码,展示了如何在实际应用中使用newCachedThreadPool。

newCachedThreadPool是ThreadPoolExecutor的一种实现。如代码:

public static ExecutorService newCachedThreadPool() {
    return new ThreadPoolExecutor(0, Integer.MAX_VALUE,
                                  60L, TimeUnit.SECONDS,
                                  new SynchronousQueue<Runnable>());
}

模拟上厕所: // 线程同时执行,不等待

@Slf4j
public class WashRoom implements Runnable {
    private int n; // 用来记录第几个人
    @Override
    public void run() {
        try {
            log.info(n+" 开始");
            int milliSecond = RandomUtils.createMilliSecond(1, 4); // 这里只要是随机秒数就行
            Thread.sleep(milliSecond);
            log.info(n +"结束,用时: "+milliSecond);

        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
    public WashRoom(int n){
        this.n=n;
    }

    public static void main(String[] args) {
//        ExecutorService executorService = Executors.newCachedThreadPool(); // 这行 和下面代码  作用一样
        ThreadPoolExecutor executorService = new ThreadPoolExecutor(
                0,      //  核心线程池数量
                Integer.MAX_VALUE,    //  线程池最大数量
                60L,    // 当线程池数量大于core时,1分钟内,如果没有其他线程来使用多余的线程,就会释放,可以理解为是为了避免频繁的启动和停止线程
                TimeUnit.SECONDS,   // 单位
                new SynchronousQueue<Runnable>()    //   阻塞队列的具体实现
        );
        for (int i = 0; i < 5; i++) {  // 5个人上厕所
            executorService.execute(new WashRoom(i));
        }
        executorService.shutdown(); // 别忘了关闭

    }
}

newCachedThreadPool 和 newFixedThreadPool的区别

newFixedThreadPool 运行中开启线程的数量是固定的。
newCachedThreadPool 会自动调节,如果某个线程一段时间不用。就会回收。更加的节省资源。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值