当前位置: 首页 > news >正文

Java 官方提供了哪几种线程池,分别有什么特点?

JDK 中提供了 5 中不同线程池的创建方式:

newCachedThreadPool

newCachedThreadPool, 是一种可以缓存的线程池,它可以用来处理大量短期的突发流量。
它的特点有三个,最大线程数是 Integer.MaxValue,线程存活时间是 60 秒, 阻塞队列用的是 SynchronousQueue,这是一种不存才任何元素的阻塞队列,也就是每提交一个任务给到线程池,都会分配一个工作线程来处理,由于最大线程数没有限制。所以它可以处理大量的任务,另外每个工作线程又可以存活 60s,使得这些工作线程可以缓存起来应对更多任务的处理。

newFixedThreadPool

newFixedThreadPool,是一种固定线程数量的线程池。它的特点是核心线程和最大线程数量都是一个固定的值如果任务比较多工作线程处理不过来,就会加入到阻塞队列里面等待。

newSingleThreadExecutor

newSingleThreadExecutor,只有一个工作线程的线程池。并且线程数量无法动态更改,因此可以保证所有的任务都按照 FIFO 的方式顺序执行。

newScheduledThreadPool

newScheduledThreadPool,具有延迟执行功能的线程池可以用它来实现定时调度。

newWorkStealingPool

newWorkStealingPool,Java8 里面新加入的一个线程池它内部会构建一个 ForkJoinPool,利用工作窃取的算法并行处理请求。

总结

这些线程都是通过工具类 Executors 来构建的,线程池的最终实现类是 ThreadPoolExecutor。

 

http://www.lryc.cn/news/209569.html

相关文章:

  • DTI-ALPS处理笔记
  • LVS集群-NAT模式
  • 微服务技术导学
  • p5.js 开发点彩画派的绘画工具
  • Java工具库——Commons IO的50个常用方法
  • Git: 仓库clone和用户配置
  • 构建外卖小程序:技术要点和实际代码
  • ubuntu安装配置svn
  • 『Jmeter入门万字长文』 | 从环境搭建、脚本设计、执行步骤到生成监控报告完整过程
  • Unity C#中LuaTable、LuaArrayTable、LuaDictTable中数据的增删改查
  • Spring常见面试题
  • 通过Vue自带服务器实现Ajax请求跨域(vue-cli)
  • Vue2-计算属性的用法
  • SM3加密udf
  • ce从初阶到大牛(两台主机免密登录)
  • CS224W2.3——传统基于特征的方法(图层级特征)
  • 【CSS】包含块
  • [SpringCloud] Nacos 简介
  • TypeScript - 字符串的字面类型
  • CRM客户管理系统源码 带移动端APP+H5+小程序
  • Mac版好用的Git客户端 Fork 免激活
  • 有一个带头结点的单链表L,设计一个算法使其元素递增有序
  • JAVA将EEE MMM dd HH:mm:ss zzz yyyy日期格式化为yyyy-MM-dd HH:mm:ss形式
  • 【Qt】文件系统
  • PostgreSQL 基础知识
  • 基于 ResNet18 架构使用 deformable convolution的车道线检测
  • C++in/out输入输出流[IO流]
  • MongoDB的安装
  • SQL查询优化---如何查询截取分析
  • vue3基础流程