源码阅读之线程池

一. 接口Executor,有一个抽象方法execute

二. 接口ExecutorService 继承了Executor,添加了优雅关闭和提交方法。

三. 抽象类AbstractExecutorService实现了接口ExecutorService,实现了submit方法,提交任务去执行,返回获取未来执行结果的Future对象。使用了模板方法模式,execute方法来自接口Executor,该抽象类中未实现,交给其子类实现。

四. ThreadPoolExecutor继承了抽象类AbstractExecutorService,实现了execute方法,用于执行runnable任务。

实现细节分为三步,
1. 如果运行线程小于corePoolSize,尝试开启一个新线程,否则尝试进入工作队列。
2. 工作队列未满,则尝试进入工作队列。否则判断是否超出最大线程数。
3. 如果未超出最大线程数,则尝试开启一个新的线程,否则按照饱和策略处理无法执行的任务。

优雅关闭方法,
在其中执行当前已经提交的任务,不接受新的任务。如果已关闭,调用没有效果。

五. 工具类Executors
提供static的工具方法,为用户提供封装好的具有各种特性的线程池。
newSingleThreadEexecutor单个线程的线程池
newFixedThreadPool固定数量的线程池。
newCachedThreadPool缓存的,可动态伸缩的线程池
后两个底层都是ThreadPoolExecutor,不过是提前设置好了参数。
全部评论

相关推荐

11-06 23:30
已编辑
华中师范大学 后端工程师
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务