线程池的工作原则揭秘:如何合理管理线程数量?

news2024/12/27 12:21:28

大家好,我是小米,一个热爱技术分享的小伙伴。在多线程编程中,线程池是一种非常实用的工具,可以帮助我们更好地管理线程,提高程序的性能和稳定性。今天,我将详细介绍线程池的概念、使用方法以及常用参数,希望能对大家有所帮助。

 

为什么要使用线程池?

在多线程编程中,频繁地创建和销毁线程是一种比较消耗资源的操作。而线程池可以在程序启动时就创建一定数量的线程,并重复使用它们来处理任务。这样可以避免线程频繁创建和销毁的开销,提高了程序的执行效率。同时,线程池还可以控制线程的数量,避免线程过多导致资源耗尽或线程过少导致任务处理速度过慢。因此,使用线程池可以更好地平衡系统的负载,提高程序的性能和响应速度。

线程池的各个参数详细介绍

  • corePoolSize(核心线程数): corePoolSize表示线程池中的核心线程数量,即线程池中始终保持的活动线程数量。如果当前线程池中的线程数量小于核心线程数,会直接创建新的线程来执行任务。
  • maximumPoolSize(最大线程数): maximumPoolSize表示线程池中允许的最大线程数量。如果当前线程池中的线程数量大于等于核心线程数,但任务队列未满,任务会被放入队列中等待执行。如果任务队列已满,但当前线程池中的线程数量小于最大线程数,会创建新的线程来执行任务。
  • keepAliveTime(线程空闲时间): keepAliveTime表示线程空闲时的存活时间。如果线程空闲时间超过keepAliveTime,且线程池中的线程数量大于核心线程数,多余的线程会被销毁,以减少资源消耗。
  • unit(时间单位): unit是keepAliveTime的时间单位,可以是秒、毫秒、微秒等。通过合理设置keepAliveTime和unit,可以控制线程空闲时间的精度。
  • workQueue(任务队列): workQueue是用于存放待执行任务的队列。线程池中的线程会从任务队列中获取任务并执行。常用的任务队列有ArrayBlockingQueue、LinkedBlockingQueue、SynchronousQueue等。
  • threadFactory(线程工厂): threadFactory用于创建新的线程对象。通过实现ThreadFactory接口,可以自定义线程的创建方式。例如,可以设置线程的名称、优先级等。
  • RejectedExecutionHandler(拒绝策略): RejectedExecutionHandler用于处理线程池无法执行的任务。常见的拒绝策略有四种:
    • ThreadPoolExecutor.AbortPolicy(默认策略): 当线程池无法执行任务时,会抛出RejectedExecutionException异常。
    • ThreadPoolExecutor.CallerRunsPolicy: 当线程池无法执行任务时,会将任务返回给调用者来手动处理。
    • ThreadPoolExecutor.DiscardPolicy: 当线程池无法执行任务时,会直接丢弃任务,不会抛出任何异常。
    • ThreadPoolExecutor.DiscardOldestPolicy: 当线程池无法执行任务时,会丢弃最旧的任务,然后尝试再次执行当前任务。

线程池工作原则

线程池遵循以下工作原则:

  1. 如果当前线程池中的线程数量小于核心线程数,会直接创建新的线程来执行任务。
  2. 如果当前线程池中的线程数量大于等于核心线程数,但任务队列未满,任务会被放入队列中等待执行。
  3. 如果任务队列已满,但当前线程池中的线程数量小于最大线程数,会创建新的线程来执行任务。
  4. 如果当前线程池中的线程数量达到最大线程数,且任务队列已满,根据指定的拒绝策略来处理无法执行的任务。

四种线程池工具类

  • FixedThreadPool: FixedThreadPool是一种固定大小的线程池,它的核心线程数和最大线程数是相等的,任务队列使用LinkedBlockingQueue。适用于负载较重且任务数量相对固定的场景,如电商商品批量上架。
  • CachedThreadPool: CachedThreadPool是一种大小可变的线程池,它的核心线程数为0,最大线程数为Integer.MAX_VALUE,线程空闲时间为60秒,任务队列使用SynchronousQueue。适用于负载较轻且任务数量不确定的场景,如电商订单处理。
  • SingleThreadPool: SingleThreadPool是一种只有一个线程的线程池,它的核心线程数和最大线程数都是1,任务队列使用LinkedBlockingQueue。适用于需要保证任务按顺序执行的场景,如电商订单状态更新。
  • ScheduledThreadPool: ScheduledThreadPool是一种定时任务线程池,可以按照指定的时间间隔或延迟来执行任务。适用于需要定时执行任务的场景,比如定时任务调度,如电商秒杀活动定时开启。

根据不同的场景需求,我们可以选择合适的线程池工具类来优化程序性能和资源利用。

案例演示

假设我们有一个电商系统,需要处理用户订单,其中包括订单支付、订单发货等操作。我们可以使用ThreadPoolExecutor来创建一个线程池,来并发处理这些订单操作。

 

通过上述的示例代码,我们可以看到使用ThreadPoolExecutor创建了一个线程池,并通过processOrder方法提交订单处理任务。通过合理配置线程池的参数,我们可以灵活地控制线程的数量和工作方式,以满足电商系统中订单处理的并发需求。

END

通过合理地配置线程池参数,我们可以根据实际需求来优化电商项目的订单处理,提高处理速度和效率。

以上就是关于线程池的介绍和使用方法。希望通过本文的分享,大家对线程池有了更深入的了解。如果有任何问题或者意见,欢迎在下方留言,我们一起讨论。谢谢大家的阅读!

 

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

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

相关文章

MFC 状态栏梳理

MFC状态栏梳理 MFC状态栏,觉得挺简单的,但是用的时候总是不得劲,梳理了一下代码。理解通透些。 先说状态栏窗口怎么来的 在MainFrame里面会有一个成员变量,状态栏 m_wndStatusBar protected: // 控件条嵌入成员CMFCMenuBar …

VMware ESXi 8.0U1a 发布 - 领先的裸机 Hypervisor

VMware ESXi 8.0U1a 发布 - 领先的裸机 Hypervisor 请访问原文链接:https://sysin.org/blog/vmware-esxi-8-u1/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org 2023-06-01, VMware vSphere 8.0U1a 发布。 详见&am…

I.MX6ULL_Linux_驱动篇(36) GPIO输入驱动

在前面我们都是使用的 GPIO 输出功能,还没有用过 GPIO 输入功能,本章我们就来学习一下在 Linux 下编写 GPIO 输入驱动程序。我们使用一个 GPIO 加输入驱动程序,同时利用原子操作来对按键值进行保护。 按键驱动和 LED 驱动原理上来讲基本都是…

浅谈TTF字体和Fnt字体的本质和优缺点

前言 本篇在讲什么 浅浅对TTF字体和Fnt字体的本质了解一下 本篇的特色 具有全流程的图文教学 重实践,轻理论,快速上手 提供全流程的源码内容 ★提高阅读体验★ 👉 ♠ 一级标题 👈 👉 ♥ 二级标题 &#x1f448…

【Java 接口】接口(Interface)的定义,implements关键字,接口实现方法案例

博主:_LJaXi Or 東方幻想郷 专栏: Java | 从入门到入坟 专属:六月一日 | 儿童节 Java 接口 接口简介 🎃接口的定义 🧧接口实现类名定义 🎁接口实现类小案例 🎈后话 🎰 接口简介 &…

从架构到特性:JuiceFS 企业版首次全面解析

大多数用户是通过社区版初次接触 JuiceFS,企业版对大家来说可能比较陌生。与其他开源项目不同的是,JuiceFS 企业版比社区版更早发布,社区版的架构设计大量参考了企业版。对 JuiceFS 用户而言,这意味着社区版具有更加稳定的特性。 …

onnx模型转 ncnn 模型全连接层输出shape不对问题解决

1.简述 最近在把paddleocr 中cls分类模型通过ncnn部署框架部署时,发现onnx -> ncnn 模型的转换过程中出现问题。因为之前的项目都是使用ncnn框架部署的,只能去解决模型转换问题了。 2. 问题描述与分析 模型在onnx推理代码上正常,当把模型…

Fabric.js 复制粘贴元素

theme: smartblue 本文简介 点赞 关注 收藏 学会了 当你要复制一个 fabric 的元素时,你考虑到的是什么?是深拷贝当前选中对象再添加到画布中? 其实,fabric.js 提供了一个克隆方法,在 fabric.js 官网的案例里也有这个…

自动驾驶赛道回暖?传统Tier1加速入场,真正赢家正在浮出水面

自动驾驶赛道,在经历过去三年的持续降温之后,正在迎来新一轮上升势头。整合、并购、协作,正在成为新一轮产业周期的关键词。 本周,滴滴自动驾驶与法雷奥签署战略合作及投资意向书,法雷奥将对滴滴自动驾驶进行战略投资…

【VMware】局域网里机器A访问机器B内部的vm虚拟机

一、机器B配置 1、打开机器B上面的VMware,在菜单里找到编辑,在编辑里找到“虚拟网络编辑器” 2、选择 net 项,点击NET设置 3、填写主机端口8090,主机端口不要和其它端口冲突就行,这个端口后面会在机器A上面用到 3.1、…

111.(cesium篇)cesium地球自转

听老人家说:多看美女会长寿 地图之家总目录(订阅之前建议先查看该博客) 文章末尾处提供保证可运行完整代码包,运行如有问题,可“私信”博主。 效果如下所示: 下面献上完整代码,代码重要位置会做相应解释 <html lang="en">

电脑病毒怎么彻底清理?这3个方法可以解决!

案例&#xff1a;电脑中毒无法正常使用怎么办&#xff1f;怎么清理电脑病毒&#xff1f;如何彻底清除病毒&#xff1f;有没有小伙伴知道解决的方法&#xff1f; 在使用电脑的过程中&#xff0c;我们经常会遇到电脑中病毒的情况&#xff0c;它们能够通过各种渠道感染你的计算机…

搭建服务器环境

如果是刚安装好的操作系统 先安装源里的gcc cmake make 等 apt-get install gcc g make cmake autoconf automake libtool 1.gcc 4.8.2 (1)上传gcc 源码在source/下 把gcc-4.8.2.tar.gz放在/home/download/ cd /home/download/ tar -xzvf gcc-4.8.2.tar.gz cd gcc-4.8.2 (2)安…

[POJO]POJO的设计规范Lombok框架

POJO的设计规范 所有用于声明属性的类&#xff0c;都应该遵循以下规范&#xff1a; 存在无参数构造方法 所有属性都是私有权限&#xff08;private&#xff09;的 添加每个属性对应的Setters & Getters 添加基于所有属性的hashCode()与equals() 必须保证&#xff1a;如…

unity | 动画模块之滚动选项框

一、效果动画 如果不是你们想要的&#xff0c;就省的你们继续往下看了 二、作者的话 对于我来说&#xff0c;计算一大堆数据简直太难了&#xff0c;所以自己想了点方法 三、基本功的要求 需要会使用Scroll View 四、进入正题 1.先做一个scrollView把自己想做的东西放进去…

Ubuntu22.04 VirtualBox

Ubuntu22.04 VirtualBox 通常三种虚拟机网络连入模式 桥接网卡 虚拟网卡连入宿主机所在的路由器&#xff0c;公用一个网关地址&#xff0c;自动分配路由器ip到虚拟网卡上&#xff0c;相当于和物理机一样的地址&#xff0c;在同一网段&#xff0c;其他物理机和这个虚拟机一样…

作为一个前端Leader,当你接到一个项目时,应该如何初始化您的项目

1、分析需求 拿到需求后&#xff0c;不是立马动工&#xff0c;我们需要先了解项目的业务需求和用户需求&#xff0c;并明确项目的范围&#xff0c;包括功能点、时间和预算等&#xff0c;来确定项目需求和范围。 2、技术栈选择 根据项目的需求和范围以及团队成员的技术栈&…

aosp12 framework重大bug:contentprovider获取低概率偶现延时10s问题修复经验分享

问题背景&#xff1a; 在android12的版本上&#xff0c;陆陆续续发现一个低概率偶现的问题&#xff0c;那就是桌面第一次启动会存在显示空白10s以上&#xff0c;正常空白一般在1-2s&#xff0c;在个空白10s以上确实就属于非常严重的问题&#xff0c;但这个是一个低概率偶现问题…

Linux - 第21节 - 网络基础(数据链路层)

1.数据链路层 数据链路层解决的问题&#xff1a; • IP拥有将数据跨网络从一台主机送到另一台主机的能力&#xff0c;但IP并不能保证每次都能够将数据可靠的送到对端主机&#xff0c;因此IP需要上层TCP为其提供可靠性保证&#xff0c;比如数据丢包后TCP可以让IP重新发送数据&am…

SpringBoot使用用户输入的自定义数据源启动【附源码】

一、项目背景 不知道小伙伴们有没有遇到过这样的需求&#xff0c;就是一个项目启动时不知道数据源&#xff0c;需要项目无数据源启动后&#xff0c;用户在画面自定义录入数据源信息&#xff0c;然后项目再初始化数据库链接&#xff0c;初始化管理员用户。最后项目进入正常使用…