我是靠谱客的博主 跳跃皮皮虾,最近开发中收集的这篇文章主要介绍线程池详细介绍,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

  1. 线程池执行流程

在这里插入图片描述

  1. 线程池的状态

    • RUNNING
    • SHUTDOWN
    • STOP
    • TIDYING
    • TERMINATED
  2. 线程池优雅关闭

线程池有两个关闭方法,shutdown()shutdownNow()shutdown()切换到SHUTDOWN状态,shutdownNow()切换到STOP状态,当队列和线程池都为空的时候切换到TIDYING状态,最后执行terminated()进入到TERMINATED状态。

关闭线程池的时候,调用`shutdown()`和`shutdownNow()`线程池不会立即关闭。如果需要在线程池关闭之后做资源回收处理等,可以
调用`awaitTermination()`来等待线程池关闭;`awaitTermination()`会不断循环判断线程池是否达到了最终状态TERMAINATED。
如果是就返回,如果不是就通过 termination 条件变量阻塞一段时间,之后继续判断。

shutdown()不会清空任务队列,会等所有任务执行完成,只会中断空闲的线程;shutdownNow()会中断所有线程,清空任务队列。

    // executor.shutdownNow();
    executor.shutdown(); // 关闭线程池
    // 如果希望在线程池彻底关闭之后进行其他操作比如资源的回收等,可以:
    try {
        boolean flag = true;
        do {
            flag = !executor.awaitTermination(500, TimeUnit.MILLISECONDS);
        } while (flag);
    } catch (InterruptedException e) {
        // 异常处理
    }

线程池状态之间的迁移过程
在这里插入图片描述

  1. 线程池的拒绝策略

    • CallerRunsPolicy:调用者直接在自己线程里执行,线程池不处理;
    • AbortPolicy:线程池抛异常。默认拒绝策略;
    • DiscardPolicy:线程池直接丢掉任务;
    • DiscardOldestPolicy:删除队列中最早的任务,将当前任务入列;
  2. corePoolSize和maxPoolSize一般设置为多大

    • CPU密集型

      ​ CPU密集型就是指该任务需要大量计算而没有阻塞,CPU一直全速运行;CPU密集型只有在真正的多核CPU上才能得到加速(通过多线程)。CPU密集型任务配置尽可能少的线程数。

      CPU密集型线程数配置公式:CPU核数 + 1

    • I/O密集型

      ​ IO密集型指该任务需要大量的IO,即大量的阻塞。在单线程上运行IO密集型的任务会导致大量的CPU运算能力浪费在等待上。所以IO密集型任务中使用多线程可以大大加速程序运行。即使在单核CPU上,这种加速主要利用了被浪费掉的阻塞时间。

      由于IO密集型任务的线程并不是一直在执行任务,大部分线程都在阻塞,所以应配置尽可能多的线程

      • 配置方式一;

        IO密集型线程数配置公式一:CPU核数 * 2

      • 配置方式二

        IO密集型线程数配置公式二:CPU核数 / (1 - 阻塞系数) (阻塞系数在0.8到0.9之间)

        比如:8核 / (1 - 0.9) = 80个线程

      线程数量只增加不减少也不行。当负载降低时,可减少线程数量,如果一个线程空闲时间达到 keepAliveTime,该线程就退出。默认情况下线程池最少会保持 corePoolSize 个线程。

      maxPoolSize 最大线程数在生产环境上往往设置成corePoolSize一样,减少在处理过程中创建线程的开销

最后

以上就是跳跃皮皮虾为你收集整理的线程池详细介绍的全部内容,希望文章能够帮你解决线程池详细介绍所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(91)

评论列表共有 0 条评论

立即
投稿
返回
顶部