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

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

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

JUC源码解析(1)---- ThreadPoolExecutor 实现原理、submit()实现_第1张图片

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

JUC源码解析(1)---- ThreadPoolExecutor 实现原理、submit()实现_第2张图片

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

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

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

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

JUC源码解析(1)---- ThreadPoolExecutor 实现原理、submit()实现_第3张图片

你可能感兴趣的:(多线程)