文章目录
- 前言
- 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框架。