第一篇:Java中的线程池介绍(阿里为什么要禁用Java内置线程池?自定义线程池参数如何设置?)

一、线程池分类

Java中提供的线程池类都在  java.util.concurrent 这个包下,也就是我们说的JUC。

线程池分为两类,一类是Java内置线程池,一类是自定义线程池。

内置线程池:

  • FixedThreadPool(固定大小线程池):这种线程池包含固定数量的线程。当一个任务提交到这个线程池时,线程池中的一个线程将被分配来处理任务。如果所有线程都正在处理任务,新任务将在队列中等待,直到有线程可用。
    ExecutorService executor = Executors.newFixedThreadPool(线程数);
    

  •  CachedThreadPool(缓存线程池):缓存线程池会根据需要创建新的线程,但如果有空闲线程,则会重用它们。如果在处理任务时所有线程都处于空闲状态,并且需要执行新任务,则会创建一个新线程。当线程处于空闲状态超过指定时间时,它将被终止并从线程池中移除。
    ExecutorService executor = Executors.newCachedThreadPool();
    
  • SingleThreadExecutor(单一线程池): 单一线程池包含单个线程。与固定大小线程池不同,单一线程池中的任务是按顺序执行的。如果这个唯一的线程在执行任务时异常终止,一个新的线程将被创建来替代它。
    ExecutorService executor = Executors.newSingleThreadExecutor();
    

  • ScheduledThreadPoolExecutor(定时任务线程池):
    ScheduledExecutorService executor = Executors.newScheduledThreadPool(corePoolSize);
    
     

自定义线程池 :

  • ThreadPoolExecutor 是 Java 中用于创建自定义线程池的类,它实现了 ExecutorService 接口。与 Executors 类提供的固定、缓存和单一线程池相比,ThreadPoolExecutor 更加灵活,可以根据实际需求定制线程池的各种参数。
ThreadPoolExecutor executor = new ThreadPoolExecutor(corePoolSize, // 核心线程数 假设5maximumPoolSize, // 最大线程数 假设7keepAliveTime, // 除核心线程数外,其他线程的存活时间 (最大线程数-核心线程数)TimeUnit.SECONDS, //时间单位new ArrayBlockingQueue<Runnable>(queueCapacity), //工作队列threadFactory // 线程工厂
);

参数解释:

  1. corePoolSize(核心线程数):线程池中保持活动状态的线程数。即使线程处于空闲状态,也不会被销毁,除非设置了 allowCoreThreadTimeOut 参数为 true

  2. maximumPoolSize(最大线程数):线程池中允许创建的最大线程数。如果队列已满且当前活动线程数小于最大线程数,则会创建新线程来执行任务,直到达到最大线程数为止。

  3. keepAliveTime(线程空闲时间):当线程池中的线程数量大于核心线程数时,多余的空闲线程在被终止之前等待新任务的最长时间。

  4. workQueue(工作队列):用于保存等待执行的任务的阻塞队列。ThreadPoolExecutor 提供了多种队列实现可供选择,比如 ArrayBlockingQueueLinkedBlockingQueue 等。

  5. ThreadFactory(线程工厂):用于创建新线程的工厂。可以通过自定义线程工厂来指定线程的名称、优先级、守护状态等属性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/1287.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

哈尔滨等保测评综述

​ 定级是网络安全等级保护的首要环节和关键环节&#xff0c;可以梳理各行业、各部门、各单位的等级保护对象类型、重要程度和数量等基本信息&#xff0c;确定分级保护的重点。定级不准&#xff0c;系统备案、建设、整改、等级测评等后续工作都会失去意义&#xff0c;等级…

ElasticSearch查询时修改打分

原生的ES打分基于BM25算法&#xff0c;相比于TF-IDF已经有了较大的改进&#xff0c;但是在实际场景中往往最终的排序效果还是需要进行调整。由于直接修改索引的权重往往代价较大&#xff0c;比较经济的方式还是在查询时即时修改得分以实现排序控制。 注&#xff1a;案例测试数据…

Cordova Common Command

我的新书《Android App开发入门与实战》已于2020年8月由人民邮电出版社出版&#xff0c;欢迎购买。点击进入详情 1.安装Cordova npm install -g cordova 2.查看Cordova版本 cordov -v 3.创建项目 cordova create hello com.example.hello HelloWorld 4.添加平台 cordov…

(delphi11最新学习资料) Object Pascal 学习笔记---第10章第1节(属性的代码补全)

10.1.3 属性的代码补全 ​ 给类添加属性是一项繁琐的工作&#xff0c;IDE的编辑器可以让你在编写属性声明的初始部分&#xff08;在类内部&#xff09;时轻松自动完成属性&#xff0c;如下所示&#xff1a; typeTMyClass classpublicproperty Month : Integer;end;​ 在光标…

开源项目实现简单实用的股票回测

1 引言 之前&#xff0c;尝试做股票工具一直想做的大而全&#xff0c;试图抓取长期的各个维度数据&#xff0c;然后统计或者训练模型。想把每个细节做到完美&#xff0c;结果却陷入了细节之中&#xff0c;最后烂尾了。 最近&#xff0c;听到大家分享了一些关于深度学习、时序…

Vue+OpenLayers7入门专栏目录,OpenLayers7中文文档,OpenLayers7中文手册api,OpenLayers7中文教程

返回入门到实战汇总目录&#xff1a;汇总目录 前言 本篇作为《VueOpenLayers7入门教程》所有文章的二合一汇总目录&#xff0c;方便查找。 本专栏源码是由OpenLayers7.x版本结合Vue框架编写。本专栏基本上每章都有详细的源代码和运行示例以供参考&#xff0c;且保证每章代码都…

2024年Getx教程_Flutter+Getx系列实战教程介绍

Getx介绍&#xff1a; GetX 是 Flutter 上的一个轻量且强大的解决方案&#xff0c;它是一个轻量级的Flutter框架。Getx不仅具有状态管理的功能&#xff0c;还具有路由管理、主题管理、国际化多语言管理、Obx局部更新、MVC视图业务分离、网络请求、数据验证等功能。GetX 官方还…

微软如何打造数字零售力航母系列科普01 --- Azure顾问(AZURE Advisor)简介

Azure顾问&#xff08;AZURE Advisor&#xff09;简介 目录 一、什么是AZURE顾问&#xff08;AZURE Advisor&#xff09;&#xff1f; 二、常见问题 三、接下来的步骤 一、什么是AZURE顾问&#xff1f; AZURE顾问是一种数字云助手&#xff0c;可帮助您遵循最佳实践来优化Az…

【24届数字IC秋招总结】正式批面试经验汇总6——禾赛

文章目录 一、禾赛-数字IC验证工程师1.1 一面面试问题1.2 二面面试问题一、禾赛-数字IC验证工程师 面试时间:9.19 9.25 1.1 一面面试问题 1、自我介绍 2、研究生课题 3、build_phase从上至下还是从下至上 4、哪些phase是task phase 5、perl脚本做了什么 6、整个验证环境是怎…

openai whisper 语音转文字尝鲜

最近大模型很火&#xff0c;也试试搭一下&#xff0c;这个是openai 开源的whisper&#xff0c;用来语音转文字。 安装 按照此文档安装&#xff0c;个人习惯先使用第一个pip命令安装&#xff0c;然后再用第二个安装剩下的依赖&#xff08;主要是tiktoken&#xff09; https:/…

Docker构建Golang项目常见问题

Docker构建Golang项目常见问题 1 Dockerfile1.1 dockerfile报错&#xff1a;failed to read expected number of bytes: unexpected EOF1.2 go mod tidy: go.mod file indicates go 1.21, but maximum supported version is 1.171.3 是否指定启动文件问题 2 构建及部署 1 Docke…

【Python系列】python 如何打印带时间的日志

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

Qwen量化脚本run_gptq.py解析

Qwen量化脚本run_gptq.py解析 代码路径 https://github.com/QwenLM/Qwen/ run_gptq.py路径 https://github.com/QwenLM/Qwen/blob/main/run_gptq.py 代码解析&#xff1a; import argparse import json from typing import Dict import loggingimport torch import transfor…

音视频封装格式解析(1)——H264格式简析,I/P/B帧是什么?H264压缩原理

文章目录 1. H264编码参数2. H264编码原理2.1 压缩原理2.2 编码结构解析 3. NALU结构4. H264 annexb模式5. 补充说明5.1 I帧5.2 P帧5.3 B帧 1. H264编码参数 视频质量和⽹络带宽占⽤是相⽭盾的。通常情况下&#xff0c;视频流占⽤的带宽越⾼则视频质量也越⾼&#xff0c;需要的…

用友NC Cloud saveImageServlet/doPost接口存在任意文件上传漏洞

声明&#xff1a; 本文仅用于技术交流&#xff0c;请勿用于非法用途 由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;文章作者不为此承担任何责任。 简介 用友NC Cloud 是基于云计算技术的企业管理软件。它提…

git push 错误: RPC failed; HTTP 413 curl 22 The requested URL returned error: 413

问题 在git push时&#xff0c;发生了如下错误&#xff1a; git 提交代码报错 &#xff1a;error: RPC failed; HTTP 413 curl 22 The requested URL returned error: 413 原因分析 一般两种&#xff1a; 本地git缓存设置太小。 这个的解决方法是&#xff1a;设置缓存大小 g…

lvm动态扩容

1、场景 因项目需要&#xff0c;前期磁盘评估不准确&#xff0c;系统在用了一段时间后发现磁盘空间不够用了&#xff0c;通过查看磁盘做的有lvm&#xff0c;因此联系了云平台的进行了扩容&#xff0c;扩容后如第二部分所看到的vdb是1000G&#xff0c;但是通过查看磁盘/home/da…

网络安全产品---数据库防火墙/审计

数据库防火墙 防火墙的类型繁多&#xff0c;即使下一代防火墙或者说AI防火墙集成功能再多&#xff0c;我觉得waf与数据库防火墙也有其无法被替代的理由&#xff0c;以此记录我对数据库防火墙的理解 what 数据库防火墙是基于数据库协议分析与访问行为控制的数据库安全防护产品…

IOS 32位调试环境搭建

一、背景 调试IOS程序经常使用gdb&#xff0c;目前gdb只支持32位程序调试&#xff0c;暂不支持IOS 64位程序调试。IOS 32位程序使用GDB调试之前&#xff0c;必须确保手机已越狱&#xff0c;否则无法安装和使用GDB调试软件。下面详细介绍GDB调试IOS 32位程序的环境搭建。 二、I…

MapReduce排序机制(Hadoop)

在MapReduce中&#xff0c;排序的目的是为了方便Reduce阶段的处理&#xff0c;通常是为了将相同键的键值对聚合在一起&#xff0c;以便进行聚合操作或其他处理。 1. Map阶段的局部排序&#xff08;Local Sorting&#xff09;&#xff1a; 对于MapTask&#xff0c;它会将处理的…