Executor框架
创始人
2024-03-20 13:57:37
0

文章目录

    • 前言
    • 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框架。

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...