Executor框架

news2024/11/15 18:15:40

文章目录

    • 前言
    • Executor框架简介
    • ScheduledThreadPoolExecutor和ThreadPoolExecutor对比
    • 总结

前言

在一些场景,我们常常会用到多线程,但是线程的管理又比较麻烦。所以我们通常使用线程池来进行线程的管理,而今天我们将介绍一个java中常常 用来创建线程池的框架Executor框架。

Executor框架简介

在HotpSpot vm 模型中,java线程被一对一映射为本地操作系统线程。Java线程启动的时候会创建一个相对应的本地线程,当java线程中止的时候,这个操作系统的线程也会被回收。

Executor框架主要结构大致由三部分组成:
1.任务:包括被执行的任务需要实现的接口:Runnable接口或Callable接口
2.任务的执行:包括执行任务机制的核心接口Executor,以及继承Executor接口的ExecutorService接口。
3.异步计算结果:包括接口Fature和实现Fature接口的FatureTask类

Executor框架成员大致有四个
1.ThreadPoolExecutor:基本的线程池,一般由Excutors创建。大致会有三个类型
(1)FixedThreadPool,有着固定数量线程的线程池,通过Excutors的newFixedThreadPool方法创建

在这里插入图片描述
(2)SingleThreadExecutor,只有单个线程的线程池,通过Excutors的newSingleThreadExecutor方法创建
在这里插入图片描述
(3)CachedThreadPool,大小无界的线程池,根据需要创建线程,通过Excutors的newCachedThreadPool方法创建
在这里插入图片描述
由上面大家可以看出,他们本质其实都还是ThreadPoolExecutor,不过是对ThreadPoolExecutor(之前的文章有详细的介绍)的一些核心参数做了控制,形成不同类型的线程池。

2.ScheduledThreadPoolExecutor:一个支持定时任务调度的线程池。
在这里插入图片描述
它继承了线程池和定时任务调度服务,所以它既是线程池,又具有定时任务调度的特性。
ScheduledThreadPoolExecutor也有两种类型
(1)ScheduledThreadPool,支持若干线程的线程池,通过Excutors的newScheduledThreadPool方法创建
在这里插入图片描述
(2)SingleThreadScheduledExecutor,只包含一个线程的线程池,通过Excutors的newSingleThreadScheduledExecutor方法创建
在这里插入图片描述

3.Fature接口:Fature接口和实现Fature接口的FatureTask类用来表示异步计算结果
4.Runnable接口和Callable接口:被执行的任务需要实现的接口

ScheduledThreadPoolExecutor和ThreadPoolExecutor对比

ScheduledThreadPoolExecutor继承ThreadPoolExecutor,所以大致的基本结构和ThreadPoolExecutor还是一样的。但是为了实现周期性执行任务,ScheduledThreadPoolExecutor做了一些特殊处理,主要有三个方面
1.使用DelayQueue作为任务队列
2.获取任务方式不同:之前从队列获取任务一般是根据先进先出原则,现在获取任务根据设置的周期时间。
3.执行任务周期后增加了额外的操作:需要不断的修改执行任务的时间

总结

本篇文章介绍了Executor框架的整体结构和成员组件。希望读者阅读文章之后,能够对Executor框架有一个深入的了解,同时也希望本章内容有助于读者更熟练的使用Executor框架。

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

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

相关文章

如何通过编码器信号计算输送线/输送带线速度(飞剪、追剪算法基础)

不同品牌PLC如何采集编码器的频率(速度)信号,专栏有系列文章和详细讲解,这里不再赘述,链接地址如下: PLC通过编码器反馈值计算速度的推荐做法(算法解析+ST代码)_RXXW_Dor的博客-CSDN博客_plc运算速度PLC如何测量采集编码器的位置数据,不清楚的可以参看我的另一篇博文:…

【docker】配置深度学习环境

目录基本环境搭建问题与解决容器启动后添加端口映射安装完虚拟环境后 CUDA调用不了opencv的使用问题自定义软件包的使用基本环境搭建 容器基本操作: # 按照服务器配置拉取对应的镜像 docker pull pytorch/pytorch:1.9.0-cuda10.2-cudnn7-devel# 查看主机端口 没有信…

网站部署SSL证书是否会影响网站流量?

给网站部署SSL证书的重要性想必很多站长用户都已知悉,SSL证书是数字证书的一种,由受信任的数字证书颁发机构CA,在验证服务器身份后颁发,具有服务器身份验证和数据传输加密功能。由于SSL证书是部署在服务器上,那么SSL证…

【第二阶段:java基础】第11章:Exception异常(P442-P459)

本系列博客是韩顺平老师java基础课的课程笔记,B站:课程链接,吐血推荐的一套全网最细java教程,获益匪浅! 韩顺平P442-P4591. 异常的概念2. 常见的异常运行时异常编译异常3. 异常处理1️⃣try-catch-finally2️⃣throws4…

Java项目:SSM在线化妆品网站

作者主页:源码空间站2022 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 本项目为前后台项目,前台为普通用户登录,后台为管理员登录; 管理员角色包含以下功能: 管理员登…

Java入门笔记

目录Java入门笔记快捷键基础准备环境准备Java编译运行流程TODO自定义模板基础语法变量原理标识符标识符命名规则数据类型整数型浮点型类型转换引用数据类型面向对象类和对象判断一个对象是不是某个类方法传参可变参数基本数据类型传参字符串数据类型传参引用数据类型传参静态属…

MySQL索引事务——小记

文章目录索引概念page索引类型B树vsB树主键索引非聚簇索引覆盖索引复合索引/联合索引优化基于B树的索引hash索引事务事务的特性ACID问题隔离级别索引 概念 使用一定的数据结构,来保存索引字段(一列或多列)对应的数据。以后根据索引字段来检…

低代码常见场景【上】|如何解决业务问题

全文 2105 字 阅读时间约 7 分钟 首发于码匠技术博客 目录 低代码用例 用于解决业务问题的低代码用例 内部系统开发所面临的困境 低代码如何解决上述困境 关于码匠 低代码平台通过在开发和部署应用程序时最大限度地减少编程来减轻 IT 团队的压力,不仅可以帮助…

[附源码]Python计算机毕业设计Django农村人居环境治理监管系统

项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等。 环境需要 1.运行环境:最好是python3.7.7,…

Java+MySQL 基于Springboot的垃圾分类网站-计算机毕业设计

项目介绍 当前全球都在提倡环境保护,现在社会高速发展,我们每个人每天都会产生很多的垃圾,尤其是工业发展到一定阶段之后这些垃圾的种类也越来越多,如果随意丢弃很可能会造成环境污染,尤其是一些电池等重污染垃圾&…

前端模块化开发

1.模块化产生的背景 Javascript模块化编程,已经成为一个迫切的需求。理想情况下,开发者只需要实现核心的业务逻辑,其他都可以加载别人已经写好的模块。 但是,Javascript不是一种模块化编程语言,它不支持"类&quo…

持续的敏捷转型--我们的经验

作者:Shalini Joshi、 Syed Tamkeen Banu 在这篇文章中,我们将分享自己的经验和教训,说明组织可能在哪些方面会失败,以及可以采取哪些积极措施。 一、简介 如今,大多数组织为了获取更快的交付、更高的商业价值和更好的…

Markdown使用模板

这里写自定义目录标题欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注…

智能仓储机器人设计

目录 第一章 绪论 1 1.1 研究的背景与意义[1] 1 1.2 机器人的研究现状[4] 2 1.3机器人的发展趋势 4 1.4本文的主要研究内容 5 第二章 机器人总体方案设计 7 2.1 小型仓储机器人的功能 7 2.2 传感器系统[13] 7 2.3 移动载体 7 2.4 自由度与机器人的运作 8 2.5 控制方式的选择 9 …

Git使用及配置

一、下载安装 网上很多教程我就不出了,hh 二、配置 1.设置用户信息 //设置用户信息 git config --global user.name"xxx" git config --global user.email"xxxxx.xxx" 三、获取本地仓库 1.在电脑上创建一个空目录作为本地Git仓库 2.进入这…

【Redis】初识Redis

1.初识Redis1.1安装1.2数据结构1.2.1 通用命令1.2.2 String类型key的结构1.2.3 Hash类型2.Jedis2.1 添加依赖及配置2.2 配置StringRedisTemplte1.初识Redis Redis是一个基于内存的键值型NoSQL数据库。其具有性能优越、持久化的特点,能够支持每秒十几万次的读写操作…

前端面试题之【HTTP/HTML/浏览器】

1.说一下http与https http:超文本传输协议,https:超文本传输安全协议 区别: http传输数据是未加密的,是明文传输;https使用ssl协议对数据进行加密处理;https协议需要ca证书,费用高…

【VUE 嵌套路由】

目录 1. 嵌套路由 2. 通俗小结 1. 嵌套路由 要使用菜单显示出“点击不同的菜单项显示不同的内容”的效果&#xff0c;需要使用嵌套路由&#xff01; 因为&#xff0c;在当前设计中&#xff0c;App.vue是显示整个页面的入口&#xff0c;而App.vue就已经使用<router-view/…

应急物资仓库管理系统-3D可视化管理系统

1. 系统介绍 RFID智慧应急物资仓库可视化管理系统是杭州东识科技有限公司基于物联网RFID技术、云计算技术、3D可视化技术、数据采集技术等&#xff0c;专门为政府、军队等部门量身定制的一体化物资综合管理平台。 本系统包括&#xff1a;物资安全监控部分——提供对环境温湿度监…

[附源码]Python计算机毕业设计Django失物招领微信小程序论文

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…