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()实现》

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

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

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

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

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

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

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

    原文作者:JUC
    原文地址: https://blog.csdn.net/qingtian211/article/details/81869837
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞