展开说说:Android线程池解析

何谓线程池?本人理解是存放和管理线程的一个容器。

线程池存在的意义是什么?

第一:前面博客提到过创建和销毁线程的操作本身是有性能开销的,如果把使用的线程对象存起来下次用的时候直接取出来用就省去了一次创建和销毁的成本,使用越频繁就越能节省性能,毕竟省到就是赚到嘛。

第二:方便的管理线程,避免很多线程同时争抢资源引发阻塞。毕竟是人家封装过的,因此有专门的属性参数来控制核心线程数、最大并发数、非核心线程的最大限制时长等。

这篇文章内容计划分两部分:

介绍常用的四种线程池;

线程池种一些常用的属性参数;

Android常用的四种线程池:

//线程池 - 固定线程的
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(2);//线程池 - 缓存的
ExecutorService cachedThreadPool = Executors.newCachedThreadPool();
//线程池 -
ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(2);
//比较特殊不是以ThreadPool结尾
ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();

第一种:FixedThreadPool线程数量固定的线程池,它只有核心线程。物以稀为贵,只要线程池不销毁线程就不会被回收。当所有的线程都处于活动状态时,新任务都会处于等待状态,直到有线程空闲出来。所有的都是核心线程因此都是精英,时刻准备着能够更快速地响应外界的请求。

第二种:CachedThreadPool线程数量不固定的线程池,没有核心线程全都是非核心线程,并且最大线程数为Integer.MAX_VALUE,超时时间为60s。当线程池中所有线程都处于活动状态时,线程池会创建新的线程来处理新任务,否则就会复用空闲线程来处理,线程空闲超过60秒会被回收。比较适合执行量大但耗时较少的任务。当所有线程都处于闲置状态时,线程池中的线程都会超时而被停止,这时CacheThreadPool几乎不占任何系统资源。

第三种 ScheduledThreadPool总体线程数量不固定的线程池,核心线程数固定,非核心线程无限大,非核心线程闲置时会被立即回收。ScheduledThreadPool这类线程池主要用于执行定时任务和具有固定周期的重复任务。

第四种 SingleThreadExecutor线程数量固定的线程池,只有一个核心线程,并且无超时时间。内部只有一个核心线程,它确保所有的任务都在同一个线程中按顺序执行。用于统一外界所有任务到一个线程,这使得这些任务之间不需要处理线程同步的问题。

线程池种一些常用的属性参数

相信大家都见过一定这样一句话“Android线程池的概念来源于Java的Executor接口”,但实际我们创建线程池直接使用的Executors这个类,但但是线程池的真正实现是ThreadPoolExecutor类。因为看上面四种线程池都是通过调用Executors的四个静态方法来实现的,点进去就会发现它也是创建的ThreadPoolExecutor对象。

通过代码看一下ThreadPoolExecutor类继承关系:

它提供了一系列参数来配置线程池,通过不同的参数可以创建不同的线程池。

以下是各个参数的具体含义:

①CorePoolSize:线程池的核心线程数

默认情况下,核心线程会一直存活,即使它们处于闲置状态。但是如果将ThreadPoolExecutor的allowCoreThreadTimeOut属性设置为true,那么核心线程就会存在超时策略,这个时间间隔由keepAliveTime决定,当等待时间超过keepAliveTime时长后,核心线程就会被停止。

②maximumPoolSize:线程池能容纳的最大线程数

当活动线程数达到这个数值后,后续的新任务将会被阻塞。

③keepAliveTime:非核心线程闲置时的超时时长

超过这个时长,非核心线程就会被回收,当线程池的allowCoreThreadTimeOut属性设置为True时,keepAliveTime同样会作用于核心线程。

④unit:keepAliveTime参数的时间单位,是个枚举值秒、毫秒、分钟

⑤workQueue:线程池中的任务队列,通过线程池execute方法提交的Runnable对象会存储在该队列中。该任务队列是BlockingQueue类型,属于阻塞队列,即队列为空时取出任务的操作会被阻塞,只有队列不为空时才能进行取出操作,而在满队列时添加操作会被阻塞。

⑥threadFactory:线程工厂,作用是为线程池提供创建新线程的能力。ThreadFactory是一个接口,它只有一个方法newThread(Runnable r)用来创建线程。

线程池常用方法:

shutDown() 关闭线程池,不影响已经提交的任务会等它完成

shutDownNow() 立刻关闭线程池,并尝试去终止正在执行的线程

allowCoreThreadTimeOut(boolean value) 允许核心线程闲置超时时被回收

execute提交任务

submit 一般情况下我们使用execute来提交任务,但是有时候可能也会用到submit,使用submit的好处是submit有返回值。

粗糙一点来讲execute(runnable)提交任务时会进行以下操作,不是绝对的哈,因为有的压根就没有核心线程、又得有没有非核心线程。我们可以理解一下它的思想就是先核心线程-满了就排队-排队人也太多了就非核心线程-线程总数也超了就抛异常:

①如果线程池中运行的线程数少于核心线程数,就新建一个线程,并执行该任务。

②如果线程池中运行的线程数大于等于核心线程数,则将任务添加到执行队列中排队,等待执行;

③如果连添加执行队列都失败了那估计是真满了,此时新建一个非核心线程,并在该线程执行任务; 这一步得看情况哈,前提是你的线程池可以有非核心线程并且数量未超过最大值

④如果添加执行队列都失败并且当前线程总数已经达到最大线程数,就拒绝这个任务,抛出RejectedExecutionHandler异常。

才疏学浅,如有错误,欢迎指正,多谢。

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

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

相关文章

linux高性能服务器-线程池实现

文章目录 定义应用场景任务类型线程数量数据结构设计:任务设计:队列设计:线程池设计 接口设计 定义 线程池属于生产消费模型,管理维持固定数量线程的池式结构,避免线程频繁的创建和销毁 应用场景 当一类任务耗时&am…

怎么处理人际关系?如何幸福一辈子?人类社会发展最终结局预测?

处理人际关系的方法有很多,以下是一些建议: 建立良好的沟通:学会倾听他人,表达自己的需求和感受,以及尊重他人的观点和意见。 建立良好的互动:培养友善和尊重他人的态度,学会与他人合作和共事。…

2005-2021年全国各地级市生态环境注意力/环保注意力数据(根据政府报告文本词频统计)

2005-2021年全国各地级市生态环境注意力/环保注意力数据(根据政府报告文本词频统计) 2005-2021年全国各地级市生态环境注意力/环保注意力数据(根据政府报告文本词频统计) 1、时间:2005-2021年 2、范围:2…

C语言栈的含义与栈数据操作代码详解!

引言:在本篇博客中,我们将学到数据结构——栈,讲到栈的含义与关于栈的数据操作代码。栈可以在顺序表、双向链表以及单链表的基础上实现,而于本篇博客中,我们选择在顺序表的基础上实现栈。 更多有关C语言和数据结构知识…

常用算法汇总

作者:指针不指南吗 专栏:算法篇 🐾算法思维逻辑🐾 文章目录 1.判断闰年2.计算从某天到某天的天数3.二分4. 前缀和5.差分6.图论6.1dfs6.2走迷宫 7.最短路7.1dijkstra7.2foly 8.并查集9.数论9.1gcd lcm9.2判断素数(质数)9.3分解质因…

Hutool工具对称加密的使用

1、导入pom依赖 <dependency><groupId>cn.hutool</groupId><artifactId>hutool-crypto</artifactId><version>5.7.15</version> </dependency> 2、测试案例 import cn.hutool.crypto.Mode; import cn.hutool.crypto.Padding…

Linux设置脚本任意位置执行

记得备份 &#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 修改文件之后记得用 source 文件名 刷新 注意&#xff1a;刷新文件之后在当前窗口…

05-07 周二 Python使用并行程序取代串行加速运行,样例程序演示

简介 在进行FastBuild优化的时候&#xff0c;需要串行的获取需要的组件的特征&#xff0c;之前是串行进行的&#xff0c;但是由于之前的设计存在问题&#xff0c;因此&#xff0c;总是很低效&#xff0c;主要是如下的原因&#xff1a; 镜像需要先下载&#xff0c;然后检测运行环…

2024/5/7 QTday2

练习&#xff1a;优化登录框&#xff0c;输入完用户名和密码后&#xff0c;点击登录&#xff0c;判断账户是否为 Admin 密码 为123456&#xff0c;如果判断成功&#xff0c;则输出登录成功&#xff0c;并关闭整个登录界面&#xff0c;如果登录失败&#xff0c;则提示登录失败&a…

xhell + privoxy 手动http代理设置

xshell7 SSH -> 隧道 -> 添加 -> 类型:Dynamic(SOCKS4/5) 侦听端口:1080 privoxy https://www.privoxy.org/ 下载zip版本 解压到 E:\httpserver\privoxy_3.0.34 config.txt 中 添加 listen-address 0.0.0.0:8118 forward-socks5 / 127.0.0.1:1080 . windows11 …

Linux系统时间同步服务 ntpd 和 chrony

时间同步协议&#xff08;NTP&#xff09;&#xff0c;用于同步网络中计算机时钟的协议。它使用客户端-服务器或对等&#xff08;peer-to-peer&#xff09;体系结构&#xff0c;并使用层次化的、分层的多级系统&#xff0c;这些等级称为"stratum"。Stratum 0是精度最…

[CISCN2019 华北赛区 Day1 Web2]ikun

看到提示说一定要找到lv6 这要写脚本来爆破了&#xff0c;用bp是爆破不出来的 发现LV等级都是有参数挂着的 写个脚本看一下 import requests for i in range(1,1000):payload"http://node4.anna.nssctf.cn:28150/shop?page%d"%(i)resrequests.get(payload)if "…

【Unity】如何获得两个List各自的补集

【背景】 在项目中需要处理这样的逻辑,将所有活跃客户端的IP地址形成一个IP地址列表,与项目中已经生成按钮实例的IP按钮进行比照,如果某一个IP处于活跃状态,但是并未生成实例按钮,那么就生成实例。如果一个按钮的IP地址不存在于当前的IP地址列表中,则需要销毁这个Button…

Misc 流量分析

流量分析简介 网络流量分析是指捕捉网络中流动的数据包&#xff0c;并通过查看包内部数据以及进行相关的协议、流量分析、统计等来发现网络运行过程中出现的问题。 在CTF比赛中&#xff0c;以及各种技能大赛对于流量包的分析取证是一种十分重要的题型。通常这类题目都是会提供…

【工作记录】openjdk-22基础镜像的构建

背景 近期使用到的框架底层都用的是springboot3.0&#xff0c;要求jdk版本在17甚至更高。 于是决定制作一个基于openjdk22的基础镜像&#xff0c;本文对这一过程进行记录。 作为记录的同时也希望能够帮助到需要的朋友。 期望效果 容器内可以正常使用java相关命令且版本是2…

6.移除元素

文章目录 题目简介题目解答解法一&#xff1a;双指针代码&#xff1a;复杂度分析&#xff1a; 解法二&#xff1a;双指针优化代码&#xff1a;复杂度分析&#xff1a; 题目链接 大家好&#xff0c;我是晓星航。今天为大家带来的是 相关的讲解&#xff01;&#x1f600; 题目简…

上海计算机学会2021年1月月赛C++丙组T2康托表

题目背景 康托是一名数学家&#xff0c;他证明了一个重要的定理&#xff0c;需要使用一张表&#xff1a; 这个表的规律是&#xff1a; 从上到下&#xff1a;每一行的分子依次增大&#xff1b;从左到右&#xff1a;每一列的分母依次增大。 康托以一种不重复、不遗漏的方式&am…

基于Springboot的教学辅助系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的教学辅助系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&…

QSPI的使用

Quad SPI接口(QSPI)是一种同步串行数据链路,在主模式下提供与外部设备的通信。它类似于SPI协议,只是它有额外的数据线。 普通SPI有四条通信线路:芯片选择、时钟、MOSI和MISO。对于QSPI,可提供额外的数据线。因此,命令/数据/地址是根据所选模式通过单、四或双IO发送的。由…

Linux内核--设备驱动(七)媒体驱动框架整理--HDMI框架(1)

目录 一、引言 二、HDMI框架 ------>2.1、硬件结构 ------>2.2、上层协议 ------------>2.2.1、HDCP协议 ------>2.3、HDMI驱动源码分析 ------------>2.3.1、HDMI dts节点 ------------>2.3.2、驱动 ------------>2.3.3、热插拔 三、HDMI时序 …