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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值