线程池原理简谈

1,概述

线程池是一种池化技术,本质是减少线程对象创建销毁的开销,同对象池、连接池一样,达到对象复用的效果。那么线程池怎么复用呢?即一个或多个Thread对象怎么执行更多的Task?这里面的关键就涉及到了阻塞队列。

其一,所谓阻塞队列,是借助锁实现的生产-消费模型,

以BlockLinkedList为例,其taskFirst方法,通过notEmpy,即Condition实现阻塞等待功能,而Condition内部使用了AQS来实现锁的功能,详情可见Java Lock源码解读-CSDN博客

其二,一个线程池有一个极限,即所有的线程对象都在被使用,且达到了最大池数量时,该怎么办呢?这时就产生了Reject策略;

其三,其他参数有

核心线程池数,懒加载式创建;

最大线程数,

线程存活时间,即非核心线程的阻塞等待时间,blockQueue.poll(timeout),

线程工厂,创建线程对象的工厂模式

2,ThreadPoolExecutor解读

以一个简单例子,即ThreadPoolExecutor类为例。

完成构造参数如上,

需要理清除池化技术的实现,

1,如何生产Command?

通过execute方法,

逻辑清晰,

1,如果小于核心线程数时,直接addWorker一个

2,如果线程池状态是RUNNING,并且提供阻塞队列workQueue成功,recheck下状态二重检查,如果check pass则什么都不用做。workQueue.offer提供的command,多个消费者会通过workQueue.take获取。

3,最后,如果添加到非核心线程失败,即addWorker(command,false)返回false,则使用拒绝策略,

addWorker,添加到线程池具体Worker职责。

笔者看下addWorker细节,

这个函数第一段式,

通过CAS操作count+1,如果当前线程池状态是SHUTDOWN或STOP,直接失败。

通过core参数判断是否达到对应最大值,如果达到直接失败。

只有CAS操作成功,才break retry,进入第二段式。

1,创建一个Worker,并且传入第一个task作为参数,并且通过线程工厂创建一个Thread对象,注意newThread时将worker自己传入,其woeker实现了Runnable接口,

另外,Worker实现了AQS,初始状态setState为-1,表示创建时阻止中断。

2,使用mainLock,将新创建的work加入wokers中,

3,添加workers成功后,直接start

4,跟进到Worker#run方法,

通过runWorker启动了一个线程,笔者看下此函数细节。

1,task赋值firstTask,第一次运行不用通过从workQueue中获取task,

2,w.unlock,前文创建Worker时值-1,unlock传release传入-1,state是0,可响应中断。

3,进入无限循环,第一个task不为null,则加锁后执行task。

4,后续的task通过从getTask中获取。

当线程池状态为SHUTDOWN且STOP且队列中没有task时,返回null,线程对象就能在runWorker中返回而被销毁。

否则,通过keepAliveTime参数从阻塞队列中获取task,如果超时,r取值null,timeOut为true,符合条件的线程会退出循环而销毁。

核心便是从workQueue中获取task。

至此,线程池原理完毕。

笔者再啰嗦下,阻塞队列的超时怎么实现的?

答案很简单,通过Condition#awaitNanos传入超时时间即可在超时时返回,更具体是内部通过AQS实现调度,详见Java Lock源码解读-CSDN博客#Condition相关。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

关于各类软件下载及使用

文章目录 一、VS Code1、下载2、安装3、使用 二、Dev-C1、下载2、安装3、使用 三、VS20191、下载2、安装3、使用 四、IDEA1、下载2、安装3、使用 五、Fiddler1、下载1.1 官网下载1.2 文件下载 2、安装3、使用 一、VS Code 1、下载 2、安装 3、使用 二、Dev-C 1、下载 2、…

万能自定义表单系统源码开源版 支持普通表单、付费报名、预约服务等三合一功能

源码简介 高效、灵活地收集和管理数据对于各项运营和决策至关重要,方便了各行业对数据收集的多样化需求。分享一个万能自定义表单系统源码开源,该系统拥有强大的自定义功能和广泛的适用性,支持普通表单、付费报名、预约服务等三合一功能。 …

vuex核心概念-getters

除了state之外,有时我们还需要从state中派生出一些状态,这些状态是依赖state的,此时会用到getters。

pod介绍

一、前言 Pod 是 Kubernetes 中最小的部署单元,它可以包含一个或多个容器,以及共享的存储卷和网络命名空间,Pod 提供了一种抽象,用于组织和管理容器化的应用程序,并提供了一种灵活、轻量级的方式来部署和管理应用程序 …

【电容】芯片旁边为什么要接0.1uf(100nF)电容,退耦电容是什么意思,为什么要大电容并小电容

系列文章目录 1.元件基础 2.电路设计 3.PCB设计 4.元件焊接 5.板子调试 6.程序设计 7.算法学习 8.编写exe 9.检测标准 10.项目举例 11.职业规划 ** 一般芯片旁边为什么都会放一个小电容,而且大部分情况下都是100nF ** 1、为什么要放这个电容 首先我们知道这个…

笨方法自学python(五)-字符串和文本

字符串和文本 在这章习题中我们将使用复杂的字符串来建立一系列的变量,从中你将学到它们的用途。首先我们解释一下字符串是什么 东西。 字符串通常是指你想要展示给别人的、或者是你想要从程序里“导出”的一小段字符。Python 可以通过文本里的双引号 " 或者单…

【微服务】配置管理

Nacos配置管理 配置管理配置共享配置热更新 配置管理 将微服务集群中常用,经常变化的配置都写到一个独立的配置文件微服务中进行统一管理 配置共享 在Nacos的界面当中进行配置管理,在配置列表中添加配置 比如各个服务中的jdbc的连接配置: …

Flutter3.x get-cli中运行get init初始化项目报错如何处理

Flutter get-cli中运行get init初始化项目会提示如下错误: get init s E:\flutter\flutter study\tempstudy\misapp01> get init 1)Getx Pattern (by Kau) 2)CLEAN (by Arktekko) which architecture do you want to use? [1] unhandled exception: Synchromu…

Java Stream

1. Stream API概述 Java 8 Stream是Java 8中引入的一个新的API,用于处理集合和数组等数据结构的元素。它允许您在数据集上进行功能性操作,例如过滤、映射、排序等,而不需要编写循环或迭代器等底层代码。 Java 8 Stream与集合不同,…

网站实现微信扫码登录(利用微信开放平台实现)

第一步:微信开放平台账户申请 网址:微信开放平台 1.首先我们要做的就是进入到微信开放平台申请一个开放平台账户,获得资质! :注册需要准备营业执照、1-2个工作日审批、300元认证费 :注册之后&#xff0…

MP4提取gif怎么操作?分享一招快制作

随着各种社交媒体的发展,越来越多的人在聊天中使用gif表情包来调节自己的聊天氛围。搞笑的gif表情包能够为我们平淡的生活添砖加瓦,带给我们一些轻松和欢乐。如果想要自己制作gif动画的时候就可以用视频转gif的工具,能够在不下载软件的情况下…

1055: 邻接矩阵到邻接表

解法&#xff1a; #include<iostream> using namespace std; int arr[100][100]; int main() {int n;cin >> n;for (int i 0; i < n; i) {for (int j 0; j < n; j) {cin >> arr[i][j];}}for (int i 0; i < n; i) {for (int j 0; j < n; j) …

27、Qt自定义标题栏

一、说明 QtWidget及其子类有默认的标题栏&#xff0c;但是这个标题栏不能美化&#xff0c;有时候满足不了我们的使用需求&#xff0c;所以进行自定义标题栏 二、下载图标 在下面的链接中下载两种颜色的最大化、向下还原、最大化和关闭八个图片&#xff0c;并找一张当做图标…

【LeetCode刷题记录】简单篇-108-将有序数组转换为二叉搜索树

【题目描述】 给你一个整数数组 nums &#xff0c;其中元素已经按 升序 排列&#xff0c;请你将其转换为一棵 平衡 二叉搜索树。 【测试用例】 示例1&#xff1a; 输入&#xff1a;nums [-10,-3,0,5,9] 输出&#xff1a;[0,-3,9,-10,null,5] 解释&#xff1a;[0,-10,5,null,…

苹果 iPhone 15 Pro Max 称霸:智能手机市场势不可挡

苹果 iPhone 15 Pro Max 称霸&#xff1a;智能手机市场势不可挡 概述 在拥挤且竞争激烈的智能手机市场中&#xff0c;苹果的 iPhone 15 Pro Max 成为明显的赢家&#xff0c;在 2024 年第一季度最畅销智能手机排行榜上名列前茅。根据 Counterpoint Research 的数据&#xff0c…

【C++】string类的使用③(修改器Modifiers || 非成员函数重载Non-member function overloads)

&#x1f525;个人主页&#xff1a; Forcible Bug Maker &#x1f525;专栏&#xff1a; STL || C 目录 前言&#x1f525;修改器&#xff08;Modifiers&#xff09;**operator**appendpush_back和pop_backassigninserterasereplaceswap &#x1f525;非成员函数重载&#xff…

【声呐仿真】学习记录2.5-DAVE项目部分文档大纲

【声呐仿真】学习记录2.5-DAVE项目 一、Dave Models 模型Vehicle Models 航行器模型New Underwater Vehicle 新型水下航行器Dave ROV ModelsDave Glider ModelsManipulator Models 机械臂模型UUV Simulator Examplesrexrovrexrov2desistek saga roveca_a9Light Autonomous Unde…

二叉搜索树模拟实现

目录 认识二叉搜索树&#xff1a; 模拟实现&#xff1a; 节点结构体构建&#xff1a; insert&#xff08;插入&#xff09;: find&#xff08;查找&#xff09;&#xff1a; erase&#xff08;删除&#xff09;&#xff08;重点&#xff09;&#xff1a; 全部代码 认识二叉…

[算法][单调栈] [leetcode]316. 去除重复字母

去除重复字母 给你一个字符串 s &#xff0c;请你去除字符串中重复的字母&#xff0c;使得每个字母只出现一次。需保证 返回结果的 字典序最小&#xff08;要求不能打乱其他字符的相对位置&#xff09;。 字典序最小&#xff1a; 考虑字符串 a 与 字符串 b&#xff0c;如果字…

Pytest测试实战 —— 分布式执行!

在这篇文章中&#xff0c;我们将从头开始介绍如何使用Pytest进行测试实战&#xff0c;并探讨如何在分布式环境中执行测试。Pytest是一个功能强大且易于使用的Python测试框架&#xff0c;它提供了丰富的功能和灵活的配置选项&#xff0c;使得编写和执行测试变得简单而又高效。 …