Executor框架

前言

在一些场景,我们常常会用到多线程,但是线程的管理又比较麻烦。所以我们通常使用线程池来进行线程的管理,而今天我们将介绍一个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框架。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mark---小鑫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值