#详细介绍!!!线程池
本篇详细:
1.介绍了什么是线程池
2.使用线程池有什么好处
3.线程池的工作流程
4.线程池的各个参数介绍
5.如何编写Java代码来创建线程池
6.使用线程池的注意事项
目录
一:什么是线程池
二:为什么使用线程池来管理线程
三:线程池的工作流程
四:线程池的各个参数介绍
五:使用Java代码创建线程池
5.1 依靠Executors工厂类来创建
5.2 依靠ThreadPoolExecutor类来创建
六:使用线程池的注意事项
1.合理的设置线程的数量

一:什么是线程池
线程池总的来说:就是创建的一个进行线程管理的容器集合,主要为了提高管理线程效率,是一种多线程处理的形式。
线程池:就是开发者根据需求创建多个线程放到一个池中(逻辑意义上),来统一管理这些线程,由池中的任务队列来直接给池中的空闲线程分配任务,大致为这样的一个过程

二:为什么使用线程池来管理线程
使用线程池的主要目的就是提高线程的调度执行和管理上的效率
优势:
1.降低资源的开销
没有线程池时线程的创建和销毁一般是由操作系统来进行的,而操作系统对线程的控制一般又是不可控的,那么当线程超过空闲时间,而线程就可能会被自动销毁,此时这中反复的操作就有可能出现线程频繁创建和销毁的情况,虽然说线程的创建和销毁的效率对比进程已经优化了很多,但是依旧会造成大量的系统资源上的浪费。
那么如果利用线程池来集中创建线程进行管理,并且核心线程创建完成后,没任务也不会进行销毁。此时就大大减少了系统频繁对线程的创建和销毁造成的资源浪费了。
2.提高任务的响应速度
任务需要线程来执行,而线程由系统进行调度又是无序的,那么就有可能在任务过多时,导致系统响应该任务过慢,此时这种把任务直接让系统来分配线程执行,我们称为用户态+内核态。
当我们(用户)把一个任务交给系统来分配线程(内核)来进行执行时,此时系统不一定会直接响应去执行我们的任务,因为系统需要同时处理大量的响应,导致任务获得响应的速度较低。
如果使用我们自己创建的线程池来进行任务的响应,那么此时就是一个纯用户态的操作了。
因为线程池中有自己的线程,去执行线程池对应的任务队列中的任务,当线程空闲就直接去队列中获取其他任务,直接响应;且由于有核心线程的存在,此时线程池中的核心线程一直都在,并不会被销毁,此时也省去了创建线程进行的时间开销,进一步使得响应速度变快。
3.可管理性
利用线程池集中统一管理,监控池中的线程,避免由于线程数量过多且线程之间相互进行抢占系统资源导致线程大面积堵塞
三:线程池的工作流程
大致如下图:

1.线程池在创建时,就会指定好各个参数的数量(例如:核心线程,临时线程等)
2.线程池有一个与之对应的任务队列(由于线程池作用的环境一般是多线程并发的状态,此时任务队列也是线程安全的数据结构)
3.我们在使用线程池时只需要往线程池的任务队列中添加任务,此时
3.1如果池中的线程小于核心线程数就会创建核心线程再执行任务,且执行完不进行销毁
3.2如果池中的线程大于核心线程数,小于临时线程数,此时就会把任务分配给空闲的线程如果线程全部都被占用此时就会创建临时线程来执行任务
3.3如果池中线程数已满(核心线程数+临时线程数),此时就会运行线程池的拒绝策略
注意:线程池的拒绝策略后面单独进行讲解(重点面试题)
四:线程池的各个参数介绍
查看官方文档:
查看官方文挡,线程池的构造方法,我们可以看到如下的参数

参数介绍:
1. int corePoolSize :核心线程数
线程池中的核心线程创建之后就不会被销毁,需要用的时候,直接安排任务
2. int maximumPoolSize:最大线程数
最大线程数就是线程池允许同时存在的线程的最大数量:核心线程数+临时线程数
临时线程在执行完任务之后,空闲一定的时间会自动销毁,需要用的时候再创建
3.long keepAliveTime:临时线程的空闲存活时间
与第2个对应,临时线程空闲一定时间后会自动销毁,而keepAliveTime就是设置的空闲时间
4.TimeUnit unit:时间单位
时间参数的单位:例如TimeUnit SECOND(秒),设置时间单位为秒
5.BlockingQueue<Runnable> workQueue:堵塞队列(用于记录存储需要执行的任务)
workQueue就是我们前面一直说的任务队列,线程池中都有一个用于记录任务的队列
BlockingQueue 为一个线程安全的阻塞队列,参数为Runnable:为一个实际任务,通过重写重写run方法来描述具体的任务逻辑
6.ThreadFactory threadFactory:工厂类:用于辅助线程创建的类(参考工厂模式)
7.RejectedExecutionHandler handler:线程池的拒绝策略
指定线程池的拒绝策略,如果线程池满了,依旧在添加任务,那么就可根据设置的拒绝策略来进行拒绝(专门讲线程池拒绝策略的时候再详细介绍)
五:使用Java代码创建线程池
5.1 依靠Executors工厂类来创建
1. newFixedThreadPool(int n),返回类型为ExecutorService接口类型
指定线程池中线程的数量为n,并且这些线程都为核心线程
ExecutorService pool = Executors.newFixedThreadPool(10);
2.newSingleThreadPool(),返回类型为ExecutorService接口类型
单例线程池,固定线程池中的线程数量为1,且为核心线程
ExecutorService pool = Executors.newSingleThreadExecutor();
3.newCatchThreadPool(),返回类型为ExecutorService接口类型
创建的线程池中核心线程数为0,最大线程数为Integer.MAX_VALUE
keepAliveTime:60 ; TimeUnit为SECOND(秒):临时线程空闲等待时间为60秒,时间到了自动销毁
总结:以这种方式创建的线程池,池中的线程都是临时线程
ExecutorService pool = Executors.newCachedThreadPool();
4.newScheduledThreadPool(int n),返回类型为ScheduledExecutorSerives接口类型
定时任务线程池:其中可设置池中线程定时或者周期性的执行池中的任务
n为核心线程数
介绍几种该线程池的安排任务的方法区别
4.1 调用schedule方法个线程池安排任务(普通定时任务)
4.2 调用scheduleAtFixedRate方法给线程池安排周期性任务(从任务开始时计算周期定时时间)
4.3调用scheduleWithFixedDelay方法给线程池安排周期性任务(从任务结束开始计算周期定时时间)
//1.普通定时任务
pool.scheduleAtFixedRate(new Runnable() {@Overridepublic void run() {System.out.println("hello1");}
},2,TimeUnit.SECONDS);//2.周期任务
pool.scheduleAtFixedRate(new Runnable() {@Overridepublic void run() {System.out.println("hello1");}
},2,5,TimeUnit.SECONDS);//3.周期任务
pool.scheduleWithFixedDelay(new Runnable() {@Overridepublic void run() {System.out.println("hello2");}
},2,5,TimeUnit.SECONDS);
上诉三个代码的作用:
1. 安排了一个打印hello1的任务,定时2秒后执行任务
2.安排了一个周期性打印hello2的任务,定时2秒后执行,并且从任务开始执行时开始计算,5秒后再次执行该任务,以这种周期执行
3.安排了一个周期性打印hello3的任务,定时2秒后执行,并且从任务结束是开始计算周期间隔时间,间隔时间为5秒
5.newSingleThreadScheduleExecutor();返回类型为ScheduledExecutorSerives接口类型
单个线程的定时任务或者周期任务的线程池。池中只有一个线程,其他与4基本一致
ScheduledExecutorService pool = Executors.newSingleThreadScheduledExecutor();
5.2 依靠ThreadPoolExecutor类来创建
通过ThreadPoolExecutor类来更加灵活的创建线程池,根据ThreadPoolExecutor类的构造方法传递一系列参数进行灵活创建。
代码:
BlockingQueue<Runnable> queue = new LinkedBlockingQueue<>();ThreadPoolExecutor pool = new ThreadPoolExecutor(5,10,60,TimeUnit.SECONDS,queue);
指定一个线程安全的阻塞队列来存储线程池中的任务,
new ThreadPoolExecutor(5,10,60,TimeUnit.SECONDS,queue):
表示corePoolSize(核心线程数)为5;maximumPoolSize(最大线程数)为10
keepAliveTime(临时线程最大空闲时间)为60;TimeUnit.SECOND:单位为秒
queue为任务队列
当然还可以根据需求增加其他参数,参数详情参照前面线程池参数介绍
六:使用线程池的注意事项
1.合理的设置线程的数量
线程池的工作线程数设置应根据实际情况配置,CPU密集型业务(搜索、排序等)CPU空闲时间较少,线程数就不需要设置太多。N核服务器,通过执行业务的单线程分析出本地计算时间为x,等待时间为y,则工作线程数(线程池线程数)设置为 N*(x+y)/x,能让CPU的利用率最大化
相关文章:
#详细介绍!!!线程池
本篇详细: 1.介绍了什么是线程池 2.使用线程池有什么好处 3.线程池的工作流程 4.线程池的各个参数介绍 5.如何编写Java代码来创建线程池 6.使用线程池的注意事项 目录 一:什么是线程池 二:为什么使用线程池来管理线程 三:线程池…...
【嵌入式Linux学习笔记】基于Linux官方库的标准外设驱动
对于标准的外设如LED,KEY,PWM等,以及标准通信协议,Linux都自带有标准的驱动库,不需要我们自行编写,只需要配置好相应的GPIO属性和电气属性,即可匹配相应的驱动,在应用程序中直接使用…...
网络爬虫抓包工具
📚介绍:Charles是著名的抓包工具🐂,可以抓取移动端与pc端网络访问🕷的所有数据。我们将使用它抓取我们与小程序交互的所有信息。🎇我们可以百度搜索Charles官网下载适用于自己系统的Charles安装包…...
蓝桥杯倒计时 | 倒计时17天
作者🕵️♂️:让机器理解语言か 专栏🎇:蓝桥杯倒计时冲刺 描述🎨:蓝桥杯冲刺阶段,一定要沉住气,一步一个脚印,胜利就在前方! 寄语💓:…...
【Spring Cloud Alibaba】7.Sentinel熔断器仪表盘监控
文章目录简介什么是 Sentinel控制台获取源码方式下载jar包方式启动访问服务配置项目,启用Sentinel完整配置测试简介 接下来我们通过Sentinel控制台来实现对服务消费者提供的熔断机制进行监控和控制,本操作先要完成之前的步骤,详情请参照【Sp…...
个人博客系统项目测试报告
项目背景介绍 背景:当在学习一项技能的时候,我们总会习惯通过博客来记录所学的知识点,方便后期遗忘时随时查看和快速复习。本次开发的Web网站程序便是为了更加轻量和方便地记录自己的学习笔记 概述:一个Web网站程序,…...
flutter安装自用笔记
参照文章: 开发环境搭建 Flutter环境配置步骤: 1.系统配置要求 2.Java环境 3.Flutter SDK 4.Android 开发环境一、系统配置要求 操作系统:Windows 7 SP1 或更高的版本(基于 x86-64 的 64 位操作系统) 磁盘空间&…...
tomcat线程池以及在SpringBoot中的启动过程
tomcat两大组件:连接器Connector,容器Container tomcat线程池 Tomcat线程池扩展了ThreadPoolExecutor,行为稍有不同 重写了ThreadPoolExecutor的execute方法 如果总线程数达到maximumPoolSize,不会立刻抛RejectedExecutionExcept…...
第十四届中国大学生创新创业大赛
文章目录比赛官网比赛题目含金量非常高建议参加的学生推荐几个我感兴趣的题目联系比赛官网 官网地址:http://www.fwwb.org.cn/ 实际叫做:中国大学生创新创业大赛 比赛题目 题目公布查看地址:http://www.fwwb.org.cn/topic/index 题目有…...
LeetCode:322. 零钱兑换——动态规划从案例入门
🍎道阻且长,行则将至。🍓 🌻算法,不如说它是一种思考方式🍀算法专栏: 👉🏻123 一、🌱322. 零钱兑换 题目描述:给你一个整数数组coins,…...
【lwIP(第四章)】网络接口
目录一、lwIP网络接口简介二、lwIP的netif结构三、lwIP的netif相关函数1. lwIP网络接口的全局变量2. netif_add()函数3. netif_remove()函数4. netif_set_default()函数一、lwIP网络接口简介 lwIP协议栈支持多种不同的网络接口(网卡),由于网卡…...
Vue3 pinia入门篇(一)
系列文章目录 主要为了记录如何使用Pinia在Vue3中的使用方式(下面会介绍为什么使用Vue3选型) 文章目录系列文章目录不用Vue2使用Pinia举例子?1.笔者的个人看法:2.总结一、Pinia是什么1.状态管理工具(类比Vuexÿ…...
python面向对象编程解释
python是一个面向对象的编程语言 面向过程的开发语言有C,面向对象除了python还有java等语言 具体来讲: 面向过程 :举个例子,比如说,把大象装进冰箱总共分几步,第一步,把冰箱门打开,…...
ARM(IMX6U)嵌入式软件裸机开发之环境搭建与配置
目录 前沿 Ubuntu 和 Windows 文件互传 Ubuntu 下 NFS 和 SSH 服务开启 Ubuntu 交叉编译工具链安装 Source Insight 软件安装和使用 Visual Studio Code 软件的安装和使用 前沿 为什么我们要学习裸机开发呢? 1、裸机开发是了解所使用的 CPU 最直接、最简单的方…...
Java文件复制多种方法
1、InputStream与OutputStream 创建两个文件 - 源和目标。然后我们从源创建InputStream并使用OutputStream将其写入目标文件进行 java 复制文件操作。 private static void copyFileUsingStream(File source, File dest) throws IOException {InputStream is null;OutputStr…...
Java语言-----封装、继承、抽象、多态、接口
目录 前言 一.封装 1.1封装的定义 1.2访问修饰符的使用 二.继承 2.1继承的定义 2.2继承的方法 2.3继承使用注意点 三.多态 3,1多态的定义 3.2动态绑定 3.3方法重写 3.4向上(向下)转型 四.抽象 4.1抽象的概述和定义 4.2抽象的使用 五…...
基于深度学习的瓶子检测软件(UI界面+YOLOv5+训练数据集)
摘要:基于深度学习的瓶子检测软件用于自动化瓶子检测与识别,对于各种场景下的塑料瓶、玻璃瓶等进行检测并计数,辅助计算机瓶子生产回收等工序。本文详细介绍深度学习的瓶子检测软件,在介绍算法原理的同时,给出Python的…...
仿网易云小程序(一)
目录 一、项目准备 二、项目初始化 1.新建项目 2.封装service请求 三、底部导航栏的设计 四、MV页面的设计 1.将获取到的数据进行渲染 2.播放量数据进行处理转换 3.时长数据进行处理转换 五、MV组件的抽离封装 六、请求的抽离video 七、下拉重新请求新的数据 八、跳转到…...
【C++】vector模拟实现及其应用
文章目录vector的介绍vector的使用及其实现vector的定义vector iterator 的使用vector空间增长问题vector的增删查改vector的介绍 vector是表示可变大小数组的序列容器。就像数组一样,vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素…...
JS看这一篇就够啦,JS基础大全,可用于快速回顾知识,面试首选
1 JS简介 更多JS内容可以看MDN:点击传送 浏览器分成两部分:渲染引擎和 JS 引擎 渲染引擎:用来解析HTML与CSS,俗称内核,比如 chrome 浏览器的 blink ,老版本的 webkitJS 引擎:也称为 JS 解释器…...
conda相比python好处
Conda 作为 Python 的环境和包管理工具,相比原生 Python 生态(如 pip 虚拟环境)有许多独特优势,尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处: 一、一站式环境管理:…...
最新SpringBoot+SpringCloud+Nacos微服务框架分享
文章目录 前言一、服务规划二、架构核心1.cloud的pom2.gateway的异常handler3.gateway的filter4、admin的pom5、admin的登录核心 三、code-helper分享总结 前言 最近有个活蛮赶的,根据Excel列的需求预估的工时直接打骨折,不要问我为什么,主要…...
Rust 异步编程
Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...
C++ 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...
CSS设置元素的宽度根据其内容自动调整
width: fit-content 是 CSS 中的一个属性值,用于设置元素的宽度根据其内容自动调整,确保宽度刚好容纳内容而不会超出。 效果对比 默认情况(width: auto): 块级元素(如 <div>)会占满父容器…...
无人机侦测与反制技术的进展与应用
国家电网无人机侦测与反制技术的进展与应用 引言 随着无人机(无人驾驶飞行器,UAV)技术的快速发展,其在商业、娱乐和军事领域的广泛应用带来了新的安全挑战。特别是对于关键基础设施如电力系统,无人机的“黑飞”&…...
scikit-learn机器学习
# 同时添加如下代码, 这样每次环境(kernel)启动的时候只要运行下方代码即可: # Also add the following code, # so that every time the environment (kernel) starts, # just run the following code: import sys sys.path.append(/home/aistudio/external-libraries)机…...
【 java 虚拟机知识 第一篇 】
目录 1.内存模型 1.1.JVM内存模型的介绍 1.2.堆和栈的区别 1.3.栈的存储细节 1.4.堆的部分 1.5.程序计数器的作用 1.6.方法区的内容 1.7.字符串池 1.8.引用类型 1.9.内存泄漏与内存溢出 1.10.会出现内存溢出的结构 1.内存模型 1.1.JVM内存模型的介绍 内存模型主要分…...
基于Java+VUE+MariaDB实现(Web)仿小米商城
仿小米商城 环境安装 nodejs maven JDK11 运行 mvn clean install -DskipTestscd adminmvn spring-boot:runcd ../webmvn spring-boot:runcd ../xiaomi-store-admin-vuenpm installnpm run servecd ../xiaomi-store-vuenpm installnpm run serve 注意:运行前…...
在 Spring Boot 中使用 JSP
jsp? 好多年没用了。重新整一下 还费了点时间,记录一下。 项目结构: pom: <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://ww…...
