Executors源码解读——创建ExecutorService线程池

Executors源码解读——创建ExecutorService线程池

      • 〇、[源码版本] jdk 1.8
      • 一、线程池概述
      • 二、线程池创建
      • 三、Executors源码解读
        • newFixedThreadPool()
        • newWorkStealingPool()
        • newSingleThreadExecutor()
        • newCachedThreadPool()
        • newSingleThreadScheduledExecutor()

〇、[源码版本] jdk 1.8

一、线程池概述

1)线程的创建需要操作线程资源、栈空间等,大量且频繁的创建与销毁需要消耗大量时间。

2)使用线程池处理,就可以复用一组线程,把一小组任务交给线程池分发处理。

3)线程池内维护了若干数量的线程:
a.没有任务时候,这些线程处于等待状态
b.有新任务,就分配一个空闲的线程执行
c.若所有线程处于忙碌状态,新任务要么放入队列等待,要么增加一个新线程进行处理。

二、线程池创建

ExecutorService是接口,它常用的创建方式可以通过Executors的方法来创建。
在这里插入图片描述

三、Executors源码解读

为这些对象提供工厂和实用方法:在concurrent包中定义的ExecutorExecutorServiceScheduledExecutorServiceThreadFactoryCallable类。

提供的方法返回结果类型有:
a.常规配置的ExecutorService
b.常规配置的ScheduledExecutorService
c.禁止修改配置的封装后的ExecutorService
(d.将新创建的线程设置为已知状态的ThreadFactory
(e.在其他类似封闭(closure-like)的形式以外的Callable
本文主要讨论前三种。

newFixedThreadPool()

public static ExecutorService newFixedThreadPool(int nThreads)

Executors创建一个线程池,该线程池复用固定数量的线程,线程操作在共享的无界队列。在任何时候,最多nThreads个线程将正在运行处理任务。

如果在所有线程都处于忙碌状态时,提交了其他任务,它们将在队列中等待,直到有线程可用。

如果任何线程因执行期间的失败而终止,且在关闭之前,如果后续任务需要执行,一个新线程将取而代之。

池中的线程会一直存在,直到明确调用ExecutorServiceshutdown方法。

a.参数:
nThreads 池中的线程数
b.返回:
ExecutorService 新创建的线程池
c.异常
throws IllegalArgumentException
如果nThreads个数小于等于0时

newWorkStealingPool()

public static ExecutorService newWorkStealingPool(int parallelism)

创建一个线程池,它维持足够的线程来支持给定的并行度级别parallelism,并且可能会使用多个队列来减少争用。

并行度级别对应于最大的活跃线程参与数量、或可用于参与任务处理的线程数。线程的实际数量可能动态增长和收缩。work-stealing线程池不保证提交任务的执行顺序。

a.参数:
parallelism 目标并行度级别
b.返回:
ExecutorService 新创建的线程池
c.异常
throws IllegalArgumentException
如果nThreads个数小于等于0时

public static ExecutorService newWorkStealingPool()

创建一个work-stealing线程池,使用所有Runtime中的availableProcessors(可用处理器)作为其目标并行度级别。

a.参数:无
b.返回:
ExecutorService 新创建的线程池
c.异常
throws IllegalArgumentException
如果nThreads个数小于等于0时

newSingleThreadExecutor()

public static ExecutorService newSingleThreadExecutor()

创建一个使用单个工作线程无界队列中操作的Executor

请注意,如果这个单个线程由于在关闭之前的执行过程中失败而终止,如果后续任务需要执行,一个新线程将取而代之。

会保证任务按顺序执行,并且不超过一个任务,在任何给定时间内处于活跃状态。与其他等效的newFixedThreadPool(1)不同,返回的执行器保证不可重新配置以使用其他线程

a.参数:无
b.返回:
ExecutorService 新创建的线程池
c.异常:无

newCachedThreadPool()

public static ExecutorService newCachedThreadPool()

创建一个线程池,根据需要创建线程,但之前构建的线程可用时会复用它们。这些线程池通常会提高程序(execute执行许多短期异步任务的)的性能。

调用execute将复用先前构造的线程(如果可用)。如果没有可用的现有线程,则会创建一个新的线程并将其添加到线程池中。

60 秒内未使用的线程将被终止并从缓存中移除。因此,保持空闲足够长时间的线程池将不会消耗任何资源。

请注意,可以使用ThreadPoolExecutor构造函数创建具有相似属性但不同细节(例如,超时参数)的池。

a.参数:无
b.返回:
ExecutorService 新创建的线程池
c.异常:无

newSingleThreadScheduledExecutor()

public static ScheduledExecutorService newSingleThreadScheduledExecutor()

创建一个单线程执行器executor,它可以安排命令在给定的延迟后运行,或定期执行

但是请注意,如果这个单一的线程在关闭之前的执行过程中由于失败而终止,如果后续任务需要执行,一个新的线程将取而代之。

会保证任务按顺序执行,并且不超过一项任务将在任何给定时间处于活跃状态。与其他等效的newScheduledThreadPool(1)不同,返回的执行器保证不可重新配置以使用其他线程

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

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

相关文章

RIP,EIGRP,OSPF融合网络互通实验(原创)

首先看拓扑: 一个面试考官问我一个这样的问题,拓扑如上,为什么R1上的lo0 PING 不通 R6 上的lo0,说是一切都按正常配置,说是考我EIGRP的特性。我当然很纳闷,如果都正常配置怎么会不通呢,最后他告诉我主要是考…

谷歌A/B实验——重叠实验基础设施解读

谷歌A/B实验——重叠实验基础设施解读〇、来源一、背景介绍二、如何划分参数三、谷歌设计的ab实验系统3.1 域和层的设计3.1.1 基础重叠域和层设计3.1.2 具备非重叠和重叠的域和层设计3.1.2 具备非重叠的域的嵌套设计优点3.1.3 具备非重叠的域的嵌套设计缺点3.1.4 启动层&#x…

Mysql 5.7 创建索引官方解读

一、环境 Mysql 5.7 二、Mysql索引创建解读 1.概述 通常我们在使用CREATE TABLE时会创建所有的索引。索引的创建对于 InnoDB 表尤其重要,其中主键决定了数据文件中行的物理布局。 CREATE INDEX是另一种添加索引的方式,针对已经创建的表添加索引。注…

AspectJ切面自定义注解实现参数分组校验——基础概念(1)

AspectJ切面自定义注解实现参数分组校验——基础概念&#xff08;1&#xff09;一、环境二、validation-api源码解读2-1.Default源码解读2-2.valid源码解读2-3.Validation源码解读一、环境 maven 需要引入的依赖&#xff1a; <dependency><groupId>javax.valida…

主板跳线连接技巧图解

作为一名新手&#xff0c;要真正从头组装好自己的电脑并不容易&#xff0c;也许你知道CPU应该插哪儿&#xff0c;内存应该插哪儿&#xff0c;但遇到一排排复杂跳线的时候&#xff0c;很多新手都不知道如何下手。 钥匙开机其实并不神秘 还记不记得你第一次见到装电脑的时候…

为什么每个线程都需要创建一个栈?

有四个函数A、B、C、D&#xff0c;地址分别为100、200、300、400&#xff1b;有两个线程同时执行&#xff1b; 1&#xff09;假如只有一个栈 函数A在线程1中执行的时候&#xff0c;调用了函数B&#xff0c;将函数A中下一条指令的地址入栈&#xff08;104&#xff09;&#xff…

莎士比亚,肯尼迪总统,孔子,奥巴马总统,马克吐温,梵高,比尔盖茨等13位名人阔谈微博(中英双语版本)...

2019独角兽企业重金招聘Python工程师标准>>> 作者: ganzhijie 发表于 2010-09-02 10:11 原文链接 阅读: 21 评论: 0 John F. Kennedy-“Ask not what your twitter can do for you, ask what you can do for your twitter.”肯尼迪总统-“不要问你的微博能为你做些什…

centos 本地化配置

2019独角兽企业重金招聘Python工程师标准>>> 最近使用svn更新的时候经常出现一些奇怪的错误。经过查询得知是本地化环境没有配置&#xff0c;导致的。记录以下解决方法。 本人环境&#xff1a;centos 5.x 错误现象&#xff1a; [Copy to clipboard]View Code ERRORs…

MySQL连接查询

1.分类 MySQL连接可以分为&#xff1a; 1&#xff09;内连接 2&#xff09;外连接 左外连接右外连接全外连接 3&#xff09;自然连接 自然内连接(NATURAL JOIN)自然左外连接(NATURAL LEFT JOIN)自然右外连接(NATURAL RIGHT JOIN) 4&#xff09;交叉连接 2.语法 SELECT…

IP编址(包括网络地址和广播地址)

1.总述 IP地址使用32位二进数表示&#xff0c;每一个主机或路由器的接口都有全局唯一的IP地址&#xff08;NAT是个例外&#xff09;&#xff0c;它由网络号(NetID)和主机号(HostID)组成&#xff0c;它可以分为五类&#xff0c;如下&#xff1a; 2.地址划分 1&#xff09;A…

面试题:谈谈你对TCP的认识

一 TCP 1. 简介 首先&#xff0c;TCP是一个传输层协议&#xff0c;提供进程到进程之间的可靠性数据传输服务&#xff0c;还提供流量控制和差错控制等机制。 其次&#xff0c;TCP是面向连接的&#xff0c;其通信模式是全双工的&#xff1b;面向连接是指&#xff1a; 在发送数…

面试题:MySQL的innodb和myisam

一 Innodb 1. 简介 索引是一种排好序的用于快速查找的数据结构。 **根据官网手册InnoDB支持B-tree索引、聚簇索引(Clustered indexes)、全文索引(Full-text search indexes)、不支持hash索引&#xff08;InnoDB在内部利用哈希索引来实现其自适应哈希索引功能&#xff09…

用Markup Validation Service进行网页的W3C标准语法验证(c#)

W3C提供免费的Markup Validation Service&#xff0c;这是一个可以验证Html/XHtml文档的语法规范的公共服务。在某种程度上&#xff0c;有了它&#xff0c;我们再也不用为不能全面及时检测众多浏览器和五花八门的js/css不兼容性而痛不欲生了。^-^。 使用方法很简单&#xff0c;…

为什么MySQL索引更适合B+树而不是二叉树、B树

一 数据库为什么使用B树 1. 与二叉树相比 二叉树相比于顺序查找的确减少了查找次数&#xff0c;但是在最坏情况下&#xff0c;二叉树有可能退化为顺序查找。而且就二叉树本身来说&#xff0c;当数据库的数据量特别大时&#xff0c;其层数也将特别大。二叉树的高度一般是log_2…

MDOP套装之app-v安装使用及功能说明

最近尝试了瑞友天翼的虚拟化产品&#xff0c;感觉还不错&#xff0c;正好手上又下载了个mdop套装&#xff0c;顺手做了个app-v实验&#xff0c;其他实验教程后期继续推出。 一、服务端的安装 二、排序工具的安装 三、客户端的安装 四、使用排序工具虚拟化一个程序 五、发布虚…

容器技术之Dockerk8s知识笔记

本文带你快速了解Kubernetes与Docker 让你对容器与虚拟机的区别、Docker与k8s有一个快速的了解 目录 演变史容器与虚拟机的区别K8S与Docker概念DockerK8S演变史 传统部署时代&#xff1a; 早期&#xff0c;将单一的应用服务运行在物理服务器上&#xff0c;无法给服务器的应用…

Container.ItemIndex 获取reapeater行号

<div class"<%# (Container.ItemIndex)4?"class3":"class4"%>"></div>取到第五行的行号&#xff0c;用一个三元运算符来判断div的样式。 图中container.itemindex(container.ItemIndex-5)是不对的&#xff0c;最上面的代码才…

容器技术之快速了解K8S各抽象资源及组件架构

带你快速了解Kubernetes主要概念和组件架构。 Kubernetes的组件和架构比较多&#xff0c;功能也比较多。 如果详细探讨&#xff0c;每个Kubernetes组件都可以单独写篇博客详细讲解。 我们这里是快速了解&#xff0c;就写的相对比较简单一些。 主要是针对不熟悉Kubernetes的…

Python可视化神器之pyecharts

目录 概述安装参数实例 柱状图-Bar饼图-Pie折线图-Line散点图-scatter3D 柱状图-Bar3D仪表盘-Gauge雷达图-Radar词云图-WordCloud地理坐标系-Geo地图-Map概述 Pyecharts是一款将python与echarts结合的强大的数据可视化工具。使用 pyecharts 可以生成独立的网页&#xff0c;也…

腾讯的强大不是偶然,小马哥很强大

为什么80%的码农都做不了架构师&#xff1f;>>> 其实自己对于腾讯没什么好感&#xff0c;不过也没有太多的坏感&#xff0c;之前还有一篇日志&#xff0c;小批评了一下腾讯&#xff0c;今天看到小马哥写给内部员工的反思邮件。记录下两点提醒自己&#xff1a;对待敌…