当前位置:网站首页>【多线程】——Callable创建多线程
【多线程】——Callable创建多线程
2022-07-29 11:50:00 【51CTO】
之前小编的博客简单介绍了两种创建线程的方式,随着小编工作过程对这一部分的深入,对这一部分有更深入的理解,也知道其他创建多线程方式,在原来的基础在深入一下!
回顾
两种经典的线程创建方式
1、继承Thread类创建线程类
2、实现Runnable接口创建线程类
演示一种利用lambda表达式创建线程的方式
之所以能这样写应为Runnable接口为函数式接口,其中只有一个run()方法,相比之前匿名函数的写法,又简便了很多。
(ps:这两种创建方式在《【多线程】——Thread VS Runnable》中均已详细说明,此处不再详细说明)
方式三
使用Callable和Future创建线程
从Java5开始,Java提供了Callable接口,而且是函数式接口,从应用角度Callable就是Runnable接口的增强版,Callable接口提供一个call()方法作为线程执行体,与Runnable中run()方法类似,但是比run()方法更强大而且Callable接口并不是Runnable接口的子接口。
1、call()方法可以有返回值
2、call()方法可以声明抛出异常
问题来了,那Callable对象不能直接作为Thread的target,而且call()中还有返回值,也不是直接别调用,作为线程执行体被调用,该怎么样和Thread配合使用呢?
Java5提供Future接口来接收Callable接口里call()方法的返回值,并且为Future提供了一个FutureTask实现类,该实现类不仅实现了Future接口还实现了Runnable接口,这样就能作为Thread的target,与Thread结合了。
Future中提供几个方法配合Callable接口使用
1、V get():返回Callable接口中call()的返回值。调用该方法将导致程序堵塞,必须等到子线程结束才会得到返回值。
2、boolean cancel(boolean mayInterruptIfRunning):试图取消Future里关联的Callable任务
3、boolean isCancelled():如果在Callable任务正常完成前被取消,则返回true
4、boolean isDone():如果Callable任务已完成,则返回true。
Callable使用方式
1、创建Callable接口的实现类,并实现call()方法,该call()方法将作为线程执行体,且该call()方法有返回值,再创建Callable实现类的实例
2、使用FutureTask对象包装Callable对象
3、使用FutureTask作为Thread的target创建并启动新线程
4、调用FutureTask的get()来获取子线程的返回值。
demo展示Callable使用方式
Callable和Runnable不同
1、Callable规范的方式是call(),Runnable规定方式是run()。其中Runnable提交给Thread来包装下,直接启动一个线程来执行。而Callable一般提交给ExecuteService来执行
2、Callable的任务来执行可以有返回值,但是Runnable不能有返回值
3、call方法可以抛出异常,run方法不能
4、运行Callable任务可以拿到一个Future对象,表示异步计算的结果。它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的结果。通过Future对象可以了解任务执行情况,可取消任务的执行,还可获取执行结果。
关于两者更多不同展示推荐博客:Callable,Runnable的区别及用法
总结
很基础内容,算是补充上篇博客的不足了!
边栏推荐
- [SwiftUI 开发] @State @Binding @ObservedObject @EnvironmentObject
- What is kubernetes custom resource definition (CRD)?
- Insights into the development of the enterprise live broadcast industry in 2022
- 吴恩达老师机器学习课程笔记 07 正则化
- 如何对SQuAD1.1数据集进行预处理「详解版」
- 【每日SQL打卡】DAY 24丨不同国家的天气类型【难度简单】
- Building and sharing the root of the digital world: Alibaba Cloud builds a comprehensive cloud-native open source ecosystem
- 【每日SQL打卡】DAY 25丨求团队人数【难度中等】
- 游戏合作伙伴专题:BreederDAO 与《王国联盟》结成联盟
- 解决idea在debug模式下变得非常慢的问题
猜你喜欢
puzzle(017.5)联动归位
1.4, stack
DNS protocol, ICMP protocol, NAT technology
593. 有效的正方形
MarkDown高阶语法手册
Based article 】 【 learn with Rust | Rust function and process control, rounding
游戏合作伙伴专题:BreederDAO 与《王国联盟》结成联盟
Based article 】 【 learn with Rust | Rust, variables and data types
365天挑战LeetCode1000题——Day 043 有效的正方形 数学
【day04】IDEA、方法
随机推荐
惠及6亿人 投资98亿 沿江高铁武宜段最新进展来了!
微信云托管入门与实践
mysql single-line, multi-line subquery
游戏合作伙伴专题:BreederDAO 与《王国联盟》结成联盟
INVALID_ ARGUMENT : Invalid rank for input: modelInput Got: 3 Expected: 4 Please fix either the input
XSS Vulnerability Analysis
【day04】IDEA、方法
面试官培训课件(非常实用的企业内训课件)
使用Tenserboard可视化深度学习训练过程
黑马四小时入门学习记录-2|本地应用
【每日SQL打卡】DAY 22丨页面推荐【难度中等】
2.2选择排序
MFC学习备忘
DNS protocol, ICMP protocol, NAT technology
【一起学Rust | 基础篇】Rust基础——变量和数据类型
Learning with Recoverable Forgetting阅读心得
【每日SQL打卡】DAY 25丨求团队人数【难度中等】
1.4、栈
Insights into the development of the enterprise live broadcast industry in 2022
Golang realizes file upload and download