JAVA和Nginx 教程大全

网站首页 > 精选教程 正文

JAVA异步方法笔记

wys521 2024-11-19 12:53:18 精选教程 31 ℃ 0 评论

CompletableFuture 是 Java 8 中新增的一个类,用于实现异步编程。而 Spring Boot 的 @Async 注解也是一种异步编程方式。它们的主要区别在于实现方式和使用场景。

实现方式

@Async 注解是 Spring Framework 中提供的一种异步编程方式,它基于线程池来实现异步执行。当一个被注解的方法被调用时,Spring 将会将其包装在一个新的线程中并在后台执行,从而不会阻塞当前线程。

CompletableFuture 则是 Java 标准库中提供的一种异步编程方式,它基于回调函数的方式来实现异步执行。当一个 CompletableFuture 对象被创建时,它会立即返回一个未完成的结果,并在后台执行任务。当任务完成后,CompletableFuture 对象将会触发回调函数并返回结果。

使用场景

@Async 注解适用于需要进行 CPU 密集型操作的场景,例如图像处理、视频转码等。因为这些操作通常会占用大量的 CPU 时间,如果阻塞主线程则会导致系统响应变慢,影响用户体验。通过使用 @Async 注解将这些操作放到后台执行,可以提高系统的并发性能和响应速度。

CompletableFuture 则适用于需要进行 I/O 密集型操作的场景,例如网络请求、数据库查询等。这些操作通常会耗费大量的时间来等待外部资源的响应,如果阻塞主线程则同样会导致系统响应变慢,影响用户体验。通过使用 CompletableFuture 将这些操作放到后台执行,并在结果返回后触发回调函数,可以提高系统的并发性能和响应速度。

总的来说,@Async 注解和 CompletableFuture 都是异步编程的有效方式,各有其适用的场景。在需要进行异步编程时,可以根据实际情况选择使用其中一种或多种方式来提高系统的性能和可维护性。

Java completefuture实例

public class CompletableFutureExample {

public static void main(String[] args) throws Exception {

// 创建一个异步任务,用于计算 1 + 2

CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> {

try {

Thread.sleep(1000); // 模拟计算耗时

} catch (InterruptedException e) {

e.printStackTrace();

}

return 1 + 2;

});


// 处理异步任务的结果

future.thenAccept(result -> {

System.out.println("计算结果为:" + result);

});

// 等待异步任务完成

System.out.println("等待异步任务完成...");

future.get(); // 阻塞当前线程,直到任务完成

System.out.println("异步任务已完成。");

}

}

上述代码中,我们首先创建了一个 CompletableFuture 对象,并在其中定义了一个异步任务,用于计算 1 + 2。在任务执行完成后,我们通过 thenAccept() 方法来处理其返回的结果并输出到控制台。最后,我们调用 get() 方法来等待任务执行完成,并阻塞当前线程。

当运行上述代码时,我们会看到如下输出:

等待异步任务完成...

计算结果为:3

异步任务已完成。

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表