通过ExecutorService.submit()方法提交的任务,可以获取任务执行完的返回值。

在实际业务场景中,Future和Callable基本是成对出现的,Callable负责产生结果,Future负责获取结果。
1、Callable接口类似于Runnable,只是Runnable没有返回值。
2、Callable任务除了返回正常结果之外,如果发生异常,该异常也会被返回,即Future可以拿到异步执行任务各种结果;
3、Future.get方法会导致主线程阻塞,直到Callable任务执行完成。

JUC源码解析(1)---- ThreadPoolExecutor 实现原理、submit()实现

AbstractExecutorService 实现了ExecutorService 接口,实现了submit() 方法。

JUC源码解析(1)---- ThreadPoolExecutor 实现原理、submit()实现

submit() 有三种重载,参数可以是 Callable 也可以是 Runnable

同时它会返回一个 Funture 对象,通过它我们可以判断任务是否执行成功。

获得执行结果调用 Future.get() 方法,这个方法会阻塞当前线程直到任务完成。

通过submit方法提交的Callable任务会被封装成了一个FutureTask对象。例如:

JUC源码解析(1)---- ThreadPoolExecutor 实现原理、submit()实现

相关文章:

  • 2021-08-22
  • 2022-03-02
  • 2022-12-23
  • 2021-12-18
  • 2021-08-08
  • 2022-02-11
  • 2022-03-07
猜你喜欢
  • 2022-01-07
  • 2021-10-17
  • 2022-02-02
  • 2022-01-09
  • 2021-05-13
  • 2023-01-11
  • 2022-03-08
相关资源
相似解决方案