当前位置:   article > 正文

线程池之newCachedThreadPool可缓存线程池

newcachedthreadpool

java线程池

Java通过Executors提供四种线程池,分别为:
newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
newScheduledThreadPool 创建一个定长线程池,支持定时及周期性任务执行。

newSingleThreadExecutor 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。

下面我们来分析newCachedThreadPool:

这种类型的线程池特点是:

  • 工作线程的创建数量几乎没有限制(其实也有限制的,数目为Interger. MAX_VALUE), 这样可灵活的往线程池中添加线程。
  • 如果长时间没有往线程池中提交任务,即如果工作线程空闲了指定的时间(默认为1分钟),则该工作线程将自动终止。终止后,如果你又提交了新的任务,则线程池重新创建一个工作线程。
  • 在使用CachedThreadPool时,一定要注意控制任务的数量,否则,由于大量线程同时运行,很有会造成系统瘫痪。

  1. public class ThreadPoolCached {
  2. public static void main(String[] args) {
  3. ExecutorService cachedThreadPool = Executors.newCachedThreadPool();
  4. for (int i = 0; i < 10; i++) {
  5. final int index = i;
  6. try {
  7. Thread.sleep(index * 100);
  8. } catch (Exception e) {
  9. e.printStackTrace();
  10. }
  11. cachedThreadPool.execute(new Runnable() {
  12. @Override
  13. public void run() {
  14. System.out.println(index+"当前线程"+Thread.currentThread().getName());
  15. }
  16. });
  17. }
  18. }
  19. }

执行结果:


发现10个线程都是使用的线程1,线程池为无限大,当执行第二个任务时第一个任务已经完成,会复用执行第一个任务的线程,而不用每次新建线程。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/246556
推荐阅读
相关标签
  

闽ICP备14008679号