你的Java项目还在等待吗?快来学会线程池,解放你的性能!

news2025/1/23 3:24:37

在这里插入图片描述

文章目录

  • 你的Java项目还在等待吗?快来学会线程池,解放你的性能!
    • 1 什么是线程池?为什么需要它?
    • 2 线程池的参数有哪些?
    • 3 不同类型的线程池有哪些配置?

你的Java项目还在等待吗?快来学会线程池,解放你的性能!

近期迷上了举例子来结合知识点学习,尽量减少枯燥,如有错见谅哈~

1 什么是线程池?为什么需要它?

线程池是什么?

线程池是一个高效的并发处理工具,它类似于你家里的管家,可以有效地管理和调度工作任务(线程)。

想象一下,你有很多家务要做,比如洗衣服、做饭、打扫等,如果每件事情都一个人去做,可能效率不高,而且容易混乱。但如果有一个管家可以根据不同的情况安排人手,就会更有条理和高效。

在Java项目开发中,线程池的作用就类似于这个管家:它提前创建好一批线程(类似于家里的工人),这些线程随时待命,等待分配任务。当有任务需要处理时,不需要每次都创建新的线程(雇新工人),而是从线程池中取出一个空闲的线程(已有的工人),分配任务给它执行,执行完毕后该线程可以被复用,而不是立即销毁。

在代码层面,一个简单的线程池的创建可以像这样:

// 创建了一个固定大小为10的线程池
ExecutorService executor = Executors.newFixedThreadPool(10);

为什么需要它?

这种预先创建并重复利用线程的方式,极大地节省了线程创建和销毁的开销,同时避免了系统因为线程过多而导致资源耗尽或性能下降的问题。

通过合理配置线程池的大小和参数,可以更好地控制并发执行的线程数量,从而优化系统的性能和响应速度。

2 线程池的参数有哪些?

线程池的参数主要是用来配置它如何管理和调度线程的。

想象一下,你在为一个派对准备,你需要决定几个桌子和椅子,以及每个桌子上坐几个人。这些参数决定了整个派对的布置和效率。

核心池大小(corePoolSize),指定了线程池中始终保持活动状态的线程数。即使没有任务执行,这些线程也会被保留。

就像派对上至少需要几个人来保证基本的服务,这些线程会一直存在,即使没有任务可做。

// 设置核心池大小为5
int corePoolSize = 5; 

最大池大小(maximumPoolSize),定义了线程池中允许的最大线程数。当队列满了且线程池中的线程数小于最大池大小时,新任务会创建新线程执行。

相当于在派对上,你愿意容忍的最多人数。如果任务多,就会雇佣更多的人来处理。

// 设置最大池大小为10
int maximumPoolSize = 10; 

任务队列(workQueue),用来保存等待执行的任务。常见的队列包括有界队列和无界队列和先进先出队列(FIFO)和优先级队列,它们影响着任务的排队策略。

就像派对上的等候区,这里存放着还没坐下的客人。

// 使用有界队列,最大容量为100
BlockingQueue<Runnable> workQueue = new LinkedBlockingQueue<>(100); 

线程存活时间(keepAliveTime),定义了线程空闲多久后被销毁。这个参数只有在线程池的线程数大于核心池大小时才会生效。

就像派对上的工作人员,如果长时间没事做,会被安排离开。

// 线程空闲时间为60秒
long keepAliveTime = 60; 
// 时间单位为秒
TimeUnit unit = TimeUnit.SECONDS; 

拒绝策略(rejectedExecutionHandler),决定了当任务无法加入线程池时的处理方式。例如,可以选择直接抛出异常或者在调用者线程中执行任务。

就像派对上人满为患,需要安排后面来的客人去别的场地。

// 默认的拒绝策略,抛出异常
RejectedExecutionHandler handler = new ThreadPoolExecutor.AbortPolicy(); 

通过合理配置这些参数,可以根据应用程序的需求和系统的负载来优化线程池的性能和资源利用率。

例如,在处理大量短时任务的场景中,可以增加核心池大小和任务队列的容量,以提高响应速度和任务处理的并发性。

3 不同类型的线程池有哪些配置?

线程池根据不同的场景和需求提供了灵活的配置选项,通过合理地选择和配置,可以最大化地利用系统资源,提高任务执行的效率和响应速度。

固定大小线程池(FixedThreadPool),有固定数量的线程,不会根据任务数量的增减而调整。适合于任务数量已知且需要快速执行的情况。

像在派对中设置几张大小固定的桌子和椅子,每张桌子上有固定数量的座位。每个人都有固定的位置,确保派对期间座位不会超出预期。

// 创建一个固定大小为5的线程池
ExecutorService executor = Executors.newFixedThreadPool(5); 

缓存线程池(CachedThreadPool),会根据需要创建新的线程,而且在线程空闲一段时间后会回收,适合处理大量短期异步任务。

桌子和椅子根据人数的需要动态增加或减少,以适应派对规模的变化。

// 创建一个根据需求自动调整大小的线程池
ExecutorService executor = Executors.newCachedThreadPool(); 

单线程化线程池(SingleThreadExecutor),只有一个工作线程,适合需要顺序执行任务的场景,保证任务按照提交的顺序执行。

所有的客人(任务)一个接一个地坐在这张桌子旁边,确保每个任务按顺序执行。

// 创建一个只有一个线程的线程池
ExecutorService executor = Executors.newSingleThreadExecutor(); 

定时执行线程池(ScheduledThreadPool),可以延时或定期执行任务,比如每隔一段时间执行一次任务或者延迟一段时间后执行。

就像在派对中设置了几张定时餐桌,每张桌子预定在特定的时间供特定数量的人坐下。

// 创建一个具有固定大小为3的定时执行线程池
ScheduledExecutorService executor = Executors.newScheduledThreadPool(3); 

工作窃取线程池(ForkJoinPool),是一种特殊的线程池,适用于并行任务的处理,每个线程都有自己的工作队列,能够高效处理递归划分的任务。

// 创建一个工作窃取线程池
ForkJoinPool executor = new ForkJoinPool(); 

每一天都是起跑线,勇敢迈出第一步

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

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

相关文章

ctfhub文件包含

文件包含 url http://challenge-41cbfbe04828b338.sandbox.ctfhub.com:10800/ 构造url&#xff0c;利用hackabar进行Post data修改测试 http://challenge-41cbfbe04828b338.sandbox.ctfhub.com:10800/?fileshell.txt ctfhubsystem("ls"); ctfhubsystem("ls…

【漏洞复现】常见框架漏洞复现 合集

Web框架(Web framework)或者叫做Web应用框架(Web application framework)&#xff0c;是用于进行Web开发的一套软件架构。大多数的Web框架提供了一套开发和部署网站的方式。为Web的行为提供了一套支持支持的方法。使用Web框架&#xff0c;很多的业务逻辑外的功能不需要自己再去…

HexView 刷写文件脚本处理工具-基本功能介绍(三)-导出S19/HEX

菜单 导出(Export) 此项目将一系列不同的选项组合在一起,用于将内部数据存储为不同的文件格式。每种导出都可以包含一些选项,以调整输出信息。 导出为S-Record格式(Export as S-Record) Motorola S-Record格式导出数据。 记录类型将根据最高地址信息的长度自动选择。…

Android平台如何不推RTMP|不发布RTSP流|不实时录像|不回传GB28181数据时实时快照?

技术背景 我们知道&#xff0c;Android平台不管RTMP推送、轻量级RTSP服务模块还是GB28181设备接入模块&#xff0c;早期&#xff0c;如果需要实现截图功能&#xff0c;又不想依赖Android系统接口&#xff0c;最好的办法是&#xff0c;在底层实现快照截图。 快照截图&#xff…

YOLOv8由pt文件中读取模型信息

Pytorch的pt模型文件中保存了许多模型信息&#xff0c;如模型结构、模型参数、任务类型、批次、数据集等 在先前的YOLOv8实验中&#xff0c;博主发现YOLOv8在预测时并不需要指定任务类型&#xff0c;因为这些信息便保存在pt模型中&#xff0c;那么&#xff0c;今天我们便来看看…

SpringBoot外部配置文件来修改jar包属性

在jar包所在的文件夹内创建application.yml配置文件&#xff1a; 在yml文件内部添加想要修改的属性值就可以了。 随后输入下面命令来运行jar包&#xff1a; java -jar Big-Deal-Boot-0.0.1-SNAPSHOT.jar 下图是优先级顺序&#xff0c;从上往下依次变高&#xff1a;

Linux Shell编程--变量

前言&#xff1a;本博客仅作记录学习使用&#xff0c;部分图片出自网络&#xff0c;如有侵犯您的权益&#xff0c;请联系删除 变量&#xff1a; bash作为程序设计语言和其它高级语言一样也提供使用和定义变量的功能 预定义变量、环境变量、自定义变量、位置变量 一、自定义变…

【Java 第十二篇章】SpringMVC 呜呜,为啥现在面试会问呢

一、简介 Spring MVC 是 Spring 框架的一个模块&#xff0c;用于构建 Web 应用程序&#xff0c;它遵循模型 - 视图 - 控制器&#xff08;MVC&#xff09;设计模式。 二、Spring MVC 的核心组件 1、DispatcherServlet 这是 Spring MVC 的前端控制器&#xff0c;它是整个框架…

Spring Boot获取Bean的三种方式

​ 博客主页: 南来_北往 系列专栏&#xff1a;Spring Boot实战 引言 在Spring Boot中&#xff0c;Bean是一个由Spring IoC容器管理的对象。 Spring Bean是在Spring IoC容器中被实例化、组装和管理的对象&#xff0c;可以视为Spring应用的构建块。它通过提供一套丰富的注…

Centos7安装Zabbix5.0的yum安装失败的解决方案

目前由于Centos7停服以及Zabbix官方限制了其5.0版本在Centos7上安装服务版本&#xff0c;因此可能会导致安装Zabbix5.0的一些组件无法正常安装。 zabbix5.0安装参考&#xff1a;一、zabbix 5.0 部署_zabbix5.0部署-CSDN博客 问题现象 当安装到zabbix的GUI包时报如下错误&…

护眼灯真的可以护眼吗?五款专业护眼灯品牌在线分析

很多新手小白在选购护眼台灯前&#xff0c;都会思考哪个护眼台灯的效果比较好这个问题&#xff0c;因为有的无良商家因为想要降低成本&#xff0c;使用一些廉价低劣的处理器&#xff0c;台灯的电压和功率都难以保证&#xff0c;有的甚至会产生有害的辐射&#xff0c;对人体的健…

Unity入门3——脚本入门

本文使用的代码编辑器为VSCode 安装接口有&#xff1a; 通过将变量设置为public&#xff0c;可以直接在unity的Inspector面板中看到相关变量。此时可直接将需要的素材拖拽到变量处。 Awake()方法 只要物体被加到场景就会执行一次

【vue3】【elementPlus】【国际化】

1.如需从0-1开始&#xff0c;请参考 https://blog.csdn.net/Timeguys/article/details/140995569 2.使用 vue-i18n 模块&#xff1a; npm i vue-i18n3.在 src 目录下创建 locales 目录&#xff0c;里面创建文件&#xff1a;en.js、zh-cn.js、index.js 语言js文件&#xff1a;…

ICC2:检查漏tree的脚本

我正在「拾陆楼」和朋友们讨论有趣的话题&#xff0c;你⼀起来吧&#xff1f; 拾陆楼知识星球入口 前面写了innovus检查clock 漏tree的脚本&#xff0c;ICC2的脚本也相差不多&#xff0c;只需要替换少部分命令就行。原理就是检查clock pin有没有clock 定义。 foreach pin [ge…

JavaSE之常用API大全

API大全 一、Object toString 返回这个对象的字符串表示形式 当输入一个引用类型的时候,会自动调用该对象的toString方法 默认的toString方法是: 包名.类名十六进制值 Equals 用于比较两个对象是否相同,默认比较内存地址 “”:比较基本类型的时候,比较的是值的大小,而比较引用…

光伏气象站会对环境产生影响吗?

在探讨光伏气象站对环境的影响时&#xff0c;我们首先要明确其核心功能和运作原理。光伏气象站&#xff0c;作为集光伏发电与气象监测于一体的设备&#xff0c;其主要作用在于为光伏电站提供精准的气象数据支持&#xff0c;并辅助电站优化运行&#xff0c;提高发电效率。 从环境…

互联网之光与人工智能之光交相辉映,如何抓住5G人工智能红利

一、互联网之光闭幕 第六届世界互联网大会“互联网之光”虽然已经闭幕&#xff01;“科学与技术”“产业与经济”“人文与社会”“合作与治理”等4大板块20个分论坛&#xff0c;为5G人工智能时代提出了一个新的问题&#xff1a;5GAI 交相辉映&#xff0c;抓住5G人工智能红利&am…

George Danezis谈Mysticeti的吞吐量和低延迟

Sui的新共识引擎Mysticeti已经在主网上开始分阶段推出。Mysten Labs联合创始人兼首席科学家George Danezis在采访中&#xff0c;解释了吞吐量和延迟的区别&#xff0c;以及Sui上的Mysticeti如何结合这两者。 采访视频&#xff1a;https://youtu.be/A4vtyE8obXQ 中文译文&…

【前缀异或和】力扣2588. 统计美丽子数组数目

给你一个下标从 0 开始的整数数组nums 。每次操作中&#xff0c;你可以&#xff1a; 选择两个满足 0 < i, j < nums.length 的不同下标 i 和 j 。 选择一个非负整数 k &#xff0c;满足 nums[i] 和 nums[j] 在二进制下的第 k 位&#xff08;下标编号从 0 开始&#xff0…

1.数据加载时 暂无数据会晃一下再显示数据 2.判断图片加载失败后渲染占位图

工作中问题小记 这种问题正常来说都没有记录的意义 但是我是强迫症 hhh 1.在正常数据渲染时 如果为空我们会渲染(暂无数据占位图)来提示用户 通常是用数据长度来判断 但是他在刷新的时候会先弹出 <暂无数据> 的提示再显示那个数据 解决方法: 搞个标识符 必须等他请求完接…