线程池介绍

  1. 可以复用线程池的每一个资源
  2. 控制资源的总量

为什么要使用线程池

问题一:反复创建线程开销大

问题二:过多的线程会占用太多内存

解决以上两个问题的思路

• 用少量的线程——避免内存占用过多

• 让这部分线程都保持工作,且可以反复执行任务——避免生命周期的损耗

线程池的好处

  1. 加快响应速度
  2. 合理利用CPU和内存
  3. 统一管理

线程池的应用场合

  • 服务器接收到大量请求时,使用线程池技术是非常合适的,它可以大大减少线程的创建和销毁次数,提高服务器的工作效率
  • 实际上,在开发中,如果需要创建5个以上的线程,那么就可以使用线程池来管理

创建和停止线程池

线程池构造方法的参数

corePoolSize

指的是核心线程数

线程池在完成初始化后,默认情况下,线程池中并没有任何线程,线程池会等待有任务到来时,再创建新线程去执行任务

maxPoolSize

在核心线程数的基础上,额外增加的线程数的上限

添加线程规则
  1. 如果线程数小于corePoolSize,即使其他工作线程处于空闲状态,也会创建一个新线程来运行新任务。
  2. 如果线程数等于(或大于)corePoolSize但少于maximumPoolSize,则将任务放入队列。
  3. 如果队列已满,并且线程数小于maxPoolSize,则创建一个新线程来运行任务。
  4. 如果队列已满,并且线程数大于或等于maxPoolSize,则拒绝该任务。

图示如下:

  1. 通过设置corePoolSize和maximumPoolSize 相同,就可以创建固定大小的线程池。
  2. 线程池希望保持较少的线程数,并且只有在负载变得很大时才增加它。
  3. 通过设置maximumPoolSize为很高的值,例如 Integer.MAX_VALUE,可以允许线程池容纳任意数量的并发任务。
  4. 只有在队列填满时才创建多于corePoolSize的线程,如果使用的是无 界队列(例如LinkedBlockingQueue),那么线程数就不会超过corePoolSize。
keepAliveTime

如果线程池当前的线程数多于corePoolSize,那么如果多余的线程空闲时间超过keepAliveTime,它们就会被终止.

threadFactory

新的线程是由ThreadFactory创建的,默认使用Executors.defaultThreadFactory()

workQueue

有3种最常见的队列类型:

  1. 直接交接:SynchronousQueue 无缓冲功能,所有任务直接交给线程去执行
  2. 无界队列:LinkedBlockingQueue 容量无限大
  3. 有界的队列:ArrayBlockingQueue

线程池应该手动创建还是自动创建

四种常见线程池的比较

线程池里的线程数量设定为多少比较合适?

  • CPU密集型(加密、计算hash等):最佳线程数为CPU核心数的1-2倍左右。
  • 耗时IO型(读写数据库、文件、网络读写等):最佳线程数一般会大于CPU核心数很多倍

参考Brain Goetz推荐的计算方法:线程数=CPU核心数(1+平均等待时间/平均工作时间)*

停止线程池的正确方法

  1. shutdown 关闭线程池,拒绝接收新的任务请求,但已经接收的任务还会继续执行
  2. isShutdown 判断线程池是否已经关闭
  3. isTerminated 判断线程是否已经终止,终止是指所有的任务都停止
  4. awaitTermination 判断一段时间之后线程池是否终止
  5. shutdownNow 暴力地终止所有任务,关闭线程池

任务拒绝

拒绝时机

1.当Executor关闭时,提交新任务会被拒绝。

2.以及当Executor对最大线程和工作队列容量使用有限边界并且已经饱和时

四种拒绝策略
  • AbortPolicy 拒绝任务并抛出异常
  • DiscardPolicy 不会抛出异常而是默默放弃任务
  • DiscardOldestPolicy 放弃最早的任务而去执行新任务
  • CallerRunsPolicy 谁提交的任务则交给哪个线程去执行

线程池ThreadPool详解相关推荐

  1. Java线程池ThreadPool详解

    Java线程池ThreadPool详解 1. 线程池概述 1.1 线程池简介 1.2 线程池特点 1.3 线程池解决问题 2. 线程池原理分析 2.1 线程池总体设计 2.6 线程池流转状态 2.2 ...

  2. async spring 默认线程池_Spring boot注解@Async线程池实例详解

    这篇文章主要介绍了Spring boot注解@Async线程池实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 从Spring3开始提供了@A ...

  3. python线程池原理_Python定时器线程池原理详解

    这篇文章主要介绍了Python定时器线程池原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 定时器执行循环任务: 知识储备 Timer(int ...

  4. 线程池源代码详解,参数详解

    线程池源代码详解,参数详解 ThreadPoolExecutor 构造函数源代码 public ThreadPoolExecutor(int corePoolSize, int maximumPool ...

  5. java executors 详解_线程池Executors详解

    为什么要用线程池呢? 一是减少了创建和销毁线程的次数,每个工作线程都可以被重复利用,可执行多个任务; 二是可以根据系统的承受能力,调整线程池中工作线线程的数目,防止因为因为消耗过多的内存,而把服务器累 ...

  6. python停止线程池_详解python中Threadpool线程池任务终止示例代码

    需求 加入我们需要处理一串个位数(0~9),奇数时需要循环打印它:偶数则等待对应时长并完成所有任务:0则是错误,但不需要终止任务,可以自定义一些处理. 关键点 定义func函数处理需求 callbac ...

  7. java executors 详解_线程池—Executors 详解

    各位志同道合的朋友们大家好,我是一个一直在一线互联网踩坑十余年的编码爱好者,现在将我们的各种经验以及架构实战分享出来,如果大家喜欢,就关注我,一起将技术学深学透,我会每一篇分享结束都会预告下一专题 线 ...

  8. java线程池使用详解

    http://automaticthoughts.iteye.com/blog/1612388 一 简介 线程的使用在java中占有极其重要的地位,在jdk1.4极其之前的jdk版本中,关于线程池的使 ...

  9. java线程池详解及五种线程池方法详解

    基础知识 Executors创建线程池 Java中创建线程池很简单,只需要调用Executors中相应的便捷方法即可,比如Executors.newFixedThreadPool(int nThrea ...

最新文章

  1. UML关系(泛化,实现,依赖,关联(聚合,组合))
  2. .NET 正则表达式’$’符号的使用
  3. Java 设计模式 之 中介者模式(Mediator)
  4. pptpd免radius限速、限连接+自由定制功能脚本
  5. opengl es 2.0环境
  6. 使用c# .net core开发国标gb28181 sip +流媒体服务完成视频监控实例教程 亲身完美体验过程...
  7. git pull提示当前branch没有跟踪信息
  8. 地表反射率影响因素_【热岛强度可影响城市夏季降水落区】
  9. 基于React的全屏滑动插件react-fullslip
  10. Python—常用正则表达式方法
  11. 判断用户什么时候离开,以什么方式离开
  12. Linux 下安装杀毒软件 clamav
  13. java如何删除文件夹_Java如何删除文件夹和子文件夹
  14. 全面理解ADMM算法
  15. 解决前端跨域的八种方案
  16. matlab中imcrop函数的具体使用
  17. 计算机网页外文文献图书,免费外文文献网站.doc
  18. STM32学习笔记(二)
  19. Hbuilder连接NOX夜神模拟器
  20. Approximation of functions in fractional Sobolev spaces

热门文章

  1. YOLOV5训练自己目标检测模型和cpu检测
  2. wifi丢包率高怎么解决_大家有没有发现无线网络中多播的丢包率很高
  3. P2P(人对人)、O2O(线上到线下)、B2C(企业对消费者)、B2B(企业对企业的电子商务模式)、C2C(消费者对消费者的电子商务模式)、B2B2C(企业对企业对消费者的商业模式)
  4. 2022年熔化焊接与热切割考试题库及模拟考试
  5. 爱油科技基于SpringCloud的微服务实践
  6. Matplotlib绘图从零入门到实践(含各类用法详解)
  7. “用好”北斗,还看芯片——新一代旗舰芯片HD8120
  8. 新浪云平台部署Java代码
  9. JavaScript关于pako.js压缩中文字符串
  10. Bing必应地图中国API-显示兴趣点 (转)