CompletableFuture-FutureTask结合线程池提升性能

使用线程池:

返回计算结果:


2.2.3 Future编码实战和优缺点分析

优点:Future+线程池异步多线程任务配合,能显著提高程序的运行效率。

缺点:

get()阻塞---一旦调用get()方法求结果,一旦调用不见不散,非要等到结果才会离开,不管你是否计算完成,如果没有计算完成容易程序堵塞。

isDone()轮询---轮询的方式会耗费无谓的cpu资源,而且也不见得能及时得到计算结果,如果想要异步获取结果,通常会以轮询的方式去获取结果,尽量不要阻塞。

结论:Future对于结果的获取不是很友好,只能通过阻塞或轮询的方式得到任务的结果。

正常情况:


get()阻塞:

main线程被阻塞了,futureTask.get() 后过了5秒才打印main ----忙其它任务了


设置 futureTask.get() 3秒钟,过时不候

非常粗暴,直接抛异常,不建议使用

相关推荐
不光头强8 分钟前
SpringBoot 开发第三天 学习内容
java·spring boot·学习
黎雁·泠崖12 分钟前
【魔法森林冒险】12/14 场景系统:5大场景的任务串联
java·开发语言
Vic1010133 分钟前
算法D1-20260212:双指针专题
java·数据结构·算法
Codiggerworld1 小时前
从字节码到JVM:深入理解Java的“一次编写,到处运行”魔法
java·开发语言·jvm
_codemonster1 小时前
配置Tomcat时为啥要配置Artifacts
java·tomcat·firefox
无心水1 小时前
2025,一路有你!
java·人工智能·分布式·后端·深度学习·架构·2025博客之星
m0_528749001 小时前
C语言错误处理宏两个比较重要的
java·linux·算法
独自破碎E2 小时前
BISHI43 讨厌鬼进货
android·java·开发语言
MX_93592 小时前
Spring xml 方式整合第三方框架总结加案例
xml·java·spring