Executor概述

在Java类库中,任务执行的主要抽象不是Thread,而是Executor。

public interface Executor {

    void execute(Runnable command);
}

它为灵活且强大的异步任务执行框架提供了基础,该框架能支持多种不同类型的任务执行策略。它提供了一种标准的方法将任务的提交过程执行过程解耦开来,并用Runnable来表示任务。Executor的实现还提供了对生命周期的支持,以及统计信息收集、应用程序管理机制和性能监测等机制。

Executor框架的两级调度模型

对Java,Executor将多线程程序分解为若干个任务,然后使用用户级的调度器将这些任务映射为固定数量的线程。对底层,操作系统内核将这些线程映射到硬件处理器上

从上图可看出,应用程序通过Executor框架控制上层的调度,而下层的调度由操作系统内核控制,下层的调度不受应用层序的控制。

Executor框架的结构

  • 任务:Runnable接口[没有返回的任务],Callable接口[有返回的任务]
  • 任务的执行:包括任务执行机制核心接口Executor,以及继承自Executor的ExecutorService接口。
  • 异步计算的结果:Future和FutureTask

猜你喜欢

转载自blog.csdn.net/weixin_39443483/article/details/114681325