创建线程方式5-CompletableFuture
在它出现之前,我们有 Future。但 Future 有一个巨大的痛点:
- 阻塞性:
Future.get()
方法是阻塞的。一旦调用,你的线程就会被卡住,直到任务完成。这极大地浪费了线程资源。 - 功能单一:你只能获取结果或取消任务,无法在一个任务完成后自动触发另一个任务,也无法组合多个任务。
CompletableFuture
解决了这些问题,它引入了回调(Callback) 机制,实现了非阻塞的、响应式的编程模型。
在它出现之前,我们有 Future。但 Future 有一个巨大的痛点:
Future.get()
方法是阻塞的。一旦调用,你的线程就会被卡住,直到任务完成。这极大地浪费了线程资源。CompletableFuture
解决了这些问题,它引入了回调(Callback) 机制,实现了非阻塞的、响应式的编程模型。
使用线程池的 submit()
或 execute()
方法提交任务。
execute(Runnable)
: 提交不需要返回值的任务。submit(Runnable/Callable)
: 提交任务,返回一个 Future
对象,可以用来跟踪任务状态和获取结果。调用 get()
方法可以获取 Callable
返回的值Runnable
的 run()
方法没有返回值,也不能抛出受检异常。Callable
是对 Runnable
的增强,解决了这两个问题。
Callable
不能直接被 Thread
类使用,通常需要和 ExecutorService
(线程池)或 FutureTask
配合。
这个和 Thread 基本类似都是最基础的多线程实现方式,唯一不同的点是这个实现的接口模式比较灵活,你的类实现了 Runnable 接口后还能去继承其他的父类
这个是最基础的多线程使用方式了,但不推荐生产使用
第一个是因为Java 类不能支持多继承。如果你的类已经继承了另一个类,就不能再继承 Thread 类了。
第二个是 run 方法 和 Thread 对象 耦合在一起,不符合面向对象的设计原则。