JDK中的线程池

本文详细介绍了JDK中的线程池,包括固定线程池newFixedThreadPool的特点,如核心线程数等于最大线程数,适合已知任务量和耗时任务;带缓冲的线程池newCachedThreadPool,其救急线程无限创建,适合任务执行时间短的情况;以及单线程池newSingleThreadExecutor的使用场景和与newFixedThreadPool的区别。同时,还讨论了线程池中常用的方法。
摘要由CSDN通过智能技术生成

1.固定的线程池

1.1newFixedThreadPool

通过ExecutorService pool = Executors.newFixedThreadPool(5)进行创建  

进入newFixedThreadPool如下图

  public static ExecutorService newFixedThreadPool(int nThreads, ThreadFactory threadFactory) {
        return new ThreadPoolExecutor(nThreads, nThreads,
                                      0L, TimeUnit.MILLISECONDS,
                                      new LinkedBlockingQueue<Runnable>(),
                                      threadFactory);
    }

1.2进入ThreadPoolExecutor

使用线程工厂创建线程,并且为非守护线程
   public ThreadPoolExecutor(int corePoolSize,
                              int maximumPoolSize,
                              long keepAliveTime,
                              TimeUnit unit,
                              BlockingQueue<Runnable> workQueue,
                              ThreadFactory threadFactory) {
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值