前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >关于 Executor 和 ExecutorService

关于 Executor 和 ExecutorService

作者头像
WindWant
发布2020-09-11 15:12:24
4370
发布2020-09-11 15:12:24
举报
文章被收录于专栏:后端码事

一、Executor:

  • 是一个接口
  • 用于执行提交的任务
  • 解耦任务提交和执行(线程的创建及调度)

Executor的实现可以根据实际需求延展不同的逻辑:

1、对于提交的任务同步或者异步执行,如下同步执行:

代码语言:javascript
复制
class ThreadPerTaskExecutor implements Executor {
   public void execute(Runnable r) {
     new Thread(r).start();
}

2、另起线程执行任务,如下:

代码语言:javascript
复制
 class ThreadPerTaskExecutor implements Executor {
     public void execute(Runnable r) {
     new Thread(r).start();
 }

3、对于执行的任务添加限制:

代码语言:javascript
复制
class SerialExecutor implements Executor {
   final Queue<Runnable> tasks = new ArrayDeque<Runnable>();
   final Executor executor;
   Runnable active;

   SerialExecutor(Executor executor) {
     this.executor = executor;
   }

   public synchronized void execute(final Runnable r) {
     tasks.offer(new Runnable() {
       public void run() {
         try {
           r.run();
         } finally {
           scheduleNext();
         }
       }
     });
     if (active == null) {
       scheduleNext();
     }
   }

   protected synchronized void scheduleNext() {
     if ((active = tasks.poll()) != null) {
       executor.execute(active);
     }
   }
 }}

二、ExecutorService:

  • 任务执行器
  • 提供任务终止方法
  • 返回Future用以跟踪任务执行结果

1、可以被关闭,也就意味着执行器不再接受新任务

shutdown:等待已提交的任务执行完毕后关闭

shutdownNow:阻止等待的任务开始并停止当前运行的任务

对于不再使用的 ExecutorService 需要及时关闭以释放资源

2、submit:创建并返回 Future 对象,用以取消任务或者等待任务执行完成

3、invokeAny、invokeAll:批处理任务,invokeAny 等待任务中任一任务执行完成即返回,invokeAll 等待所有任务执行完成即返回

4、Executors:ExecutorService 工厂类

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-02-28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、Executor:
  • 二、ExecutorService:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档