前言
线程池可以并发执行多个任务,有些时候,我们可能想要跟踪任务的执行结果,甚至在一定时间内,如果任务没有执行完成,我们可能还想要取消任务的执行,为了支持这一特性,threadpoolexecutor提供了 futuretask 用于追踪任务的执行和取消。本篇介绍futuretask的实现原理。
类视图
为了更好的理解futuretask的实现原理,这里先提供几个重要接口和类的结构,如下图所示:
runnableadapter
threadpoolexecutor提供了submit接口用于提交任务,submit支持runnable和callable两种不同的接口,为了提供统一的对外接口,jdk在内部把runnable给包装成了一个callable,这一切是通过runnableadapter这个适配器来实现的。如下为runnableadapter的源码:
相关文章
猜你喜欢
- 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
- 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
- ASP.NET自助建站系统中的用户注册和登录功能定制方法 2025-06-10
- ASP.NET自助建站系统的域名绑定与解析教程 2025-06-10
- 个人服务器网站搭建:如何选择合适的服务器提供商? 2025-06-10