概述

在Java中,使用线程来异步执行任务。Java线程的创建与销毁需要一定的开销,如果我们为每一个任务创建一个新线程来执行,这些线程的创建与销毁将消耗大量的计算资源。同时,为每一个任务创建一个新线程来执行,这种策略可能会使处于高负荷状态的应用最终崩溃。

Java线程既是工作单元,也是执行单元。从JDK1.5开始,把工作单元与执行机制分离开来。工作单元包括Runnable 和 Callable,而执行机制由Executor框架提供。

Java从1.5版本开始,为简化多线程并发编程,引入全新的并发编程包:java.util.concurrent及其并发编程框架(Executor框架)。

Executor框架是指java 5中引入的一系列并发库中与executor相关的一些功能类,其中包括线程池,Executor,Executors,ExecutorService,CompletionService,Future,Callable等。

类关系图如下:

在Executor框架中,使用执行器(Exectuor)来管理Thread对象,从而简化了并发编程。

Executor框架简介

Executor框架的两级调度模型

在HotSpot VM的线程模型中,Java线程被一对一映射为本地操作系统线程。

Java线程启动时会创建一个本地操作系统线程;当Java线程终止时,这个操作系统线程也会被回收。操作系统会调用所有线程并将他们分配给可用的CPU。

可以将此种模式分为两层

在上层,Java多线程程序通常把应用程序分解为若干任务,然后使用用户级的调度器(Executor框架)将这些任务映射为固定数量的线程

在底层,操作系统内核将这些线程映射到硬件处理器上。

两级调度模型的示意图如下:

从图中可以看出,该框架用来控制应用程序的上层调度,下层调度由操作系统内核控制,不受应用程序控制.

Executor框架成员

任务

被执行任务需要实现的接口:Runnable接口和Callable接口

执行任务

任务执行机制的核心接口Executor,以及继承自Executor的ExecutorService接口。

Executor框架有两个关键类实现了ExecutorService接口:ThreadPoolExecutor 和 ScheduledThreadPoolExector.

异步计算的结果

Future和实现Future接口的FutureTask类。

Executor框架的类与接口

Executor是一个接口,Executor框架的基础,它将任务的提交与任务的执行分离。

Executors 线程池工厂类

AbstractExecutorService 执行框架抽象类。

ThreadPoolExecutor是线程池的核心实现类,用来执行被提交的任务。

ScheduledThreadPoolExecutor是一个实现类,可以在给定的延迟后运行命令,或者定期执行命令。ScheduledThreadPoolExecutor 比 Timer 更灵活,功能更强大。

Future接口和它的实现FutureTask类,代表异步计算的结果。

Runnable和Callable接口的实现类,都可以被ThreadPoolExecutor 或 ScheduledThreadPoolExecutor执行.

使用Executor框架

1。 主线程首先要创建实现 Runnable接口或者Callable接口的任务对象。Executors可以把一个Runnable对象封装为一个Callable对象,如下

Executors.callable(Runnale task);

或者

Executors.callable(Runnable task, Object result);

2。 然后把Runnable对象直接交给ExecutorService执行

ExecutorService.execute(Runnable command);

或者也可以把Runnable对象或Callable对象提交给ExecutorService执行。 如果执行ExecutorService.submit(…),ExecutorService将返回一个实现Future接口的对象(到目前为止的JDK中,返回的是FutureTask对象)。由于FutureTask实现了Runnable接口,我们也可以创建FutureTask类,然后直接交给ExecutorService执行。

ExecutorService.submit(Runnable task);

3。 最后,主线程可以执行FutureTask.get()方法来等待任务执行完成。主线程也可以执行FutureTask.cancel(boolean mayInterruptIfRunning)来取消此任务的执行。

java executor解读_Java-多线程框架Executor解读相关推荐

  1. java线程钥匙_Java多线程并发编程/锁的理解

    一.前言 最近项目遇到多线程并发的情景(并发抢单&恢复库存并行),代码在正常情况下运行没有什么问题,在高并发压测下会出现:库存超发/总库存与sku库存对不上等各种问题. 在运用了 限流/加锁等 ...

  2. java线程池_Java多线程并发:线程基本方法+线程池原理+阻塞队列原理技术分享...

    线程基本方法有哪些? 线程相关的基本方法有 wait,notify,notifyAll,sleep,join,yield 等. 线程等待(wait) 调用该方法的线程进入 WAITING 状态,只有等 ...

  3. java 线程包_Java 多线程——工具包

    JUC 首先来说说synchronized的有什么缺点. 它非常的死板.要么获取锁,要么等待锁,而且我们无法知晓此时这个锁有没有被人拿到,也不知道某个线程是否是上锁状态. 只有悲观锁.排他锁,没有乐观 ...

  4. 简述java的线程_Java多线程的简述

    线程与进程 进程: ​ 是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间,一个应用程序可以同时运行多个进程:进程也是程序的一次执行过程,是系统运行程序的基本单位:系统运行一个程序即是一个进 ...

  5. java 线程 组成_java多线程

    一:基本知识点 1.1线程与进程区别: 1.进程是资源分配的最小单位,线程是CPU调度的最小单位 2.一个进程由一个或多个线程组成 3.进程之间相互独立,每个进程都有独立的代码和数据空间,但同一进程下 ...

  6. java sl4j 日志_Java日志框架Slf4j+Log4j入门

    一.日志系统介绍 slf4j,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统.简答的讲就是slf4j是一系列的日志 ...

  7. Java服务提供_JAVA 服务提供者框架介绍

    服务提供者框架是指:多个服务提供者实现一个服务,系统为客户端提供多个实现,并把他们从多个实现中解耦出来.服务提供者的改变对它们的客户端是透明的,这样提供了更好的可扩展性.例如,JDBC,JMS等就是用 ...

  8. java闭合数据_java多线程中线程封闭详解

    线程封闭的概念 访问共享变量时,通常要使用同步,所以避免使用同步的方法就是减少共享数据的使用,这种技术就是线程封闭. 实现线程封闭的方法 1:ad-hoc线程封闭 这是完全靠实现者控制的线程封闭,他的 ...

  9. java线程 打印_java多线程实现 5秒一次打印当前时间

    import javax.swing.JLabel; import java.util.Date; public class Time extends JFrame implements Runnab ...

最新文章

  1. Electron的代码调试
  2. Windows10下搭建Java环境(最新教程)
  3. 《树莓派实战秘籍》——2.7 技巧27尝试Occidentalis:为(高级)教育目的的树莓派发行版...
  4. java io流文件损坏_java使用io流下载.docx. xlsx文件,出现文件损坏提示
  5. 这个省3月23日开始错时错峰开学,在校不要求戴口罩!
  6. 没有bug队——加贝——Python 练习实例 5,6
  7. STM32----摸石头过河系列(三)
  8. PHP字符编码问题之GB2312 VS UTF-8
  9. LeetCode 451. 根据字符出现频率排序(Sort Characters By Frequency)
  10. 苹果iPad Pro将转向OLED屏幕 首款明年下半年推出
  11. php门面理解,php 门面模式(外观模式)
  12. 编码 —— 差错检验
  13. Windows的同步I/O和异步I/O
  14. 怎么轻松学JAVA(三个月拿实习Offer):小猿的JAVA后端之路(持续更新)
  15. 硬盘数据丢失原因?硬盘数据恢复方法
  16. 激活navicat提示rsa public key not find的问题
  17. dsp调音一次多少钱_把手教你调音玩转DSP
  18. 小程序 导航按钮列表实现navigator
  19. 阿里云服务器出网带宽和入网带宽是什么意思,5M宽带怎么计算?
  20. 华为公有云,一个关于天分与勤奋的故事

热门文章

  1. dijkstra+priority_queue+vector
  2. bat转exe工具 Bat To Exe Converter v2.4.7 绿色版
  3. newton法分形图
  4. 策略模式 是一种好策略 -07
  5. 教你如何打开android4.3和4.4中隐藏的AppOps
  6. 手动安装cloudera cdh4.2 hadoop + hbase + hive(一)
  7. Workflow之Activity
  8. Android xml资源文件中@、@android:type、@*、?、@+含义和区别
  9. java 11_Java 11 正式发布!8年免费使用!
  10. 随手记android面试题,微众银行风险模型面试随手记(一面+二面)