在 Java 中,異步編程的核心是 “不阻塞當前線程” 地執(zhí)行任務(wù),避免因等待耗時操作(如 IO、網(wǎng)絡(luò)請求)而阻塞主線程,從而提高程序的并發(fā)效率。常見的異步實現(xiàn)方式包括線程池、Future/CompletableFuture、Spring 的 @Async 注解等。以下是具體實現(xiàn)及用法:
一、基于線程池的異步(基礎(chǔ)方式)
線程池是實現(xiàn)異步的基礎(chǔ),通過將任務(wù)提交到線程池執(zhí)行,主線程無需等待任務(wù)完成。
特點:
簡單直接,通過線程池管理異步任務(wù)的執(zhí)行。
但獲取任務(wù)結(jié)果需額外處理(如用Future)。
二、基于 Future 的異步(獲取結(jié)果)
Future接口用于表示異步任務(wù)的結(jié)果,可通過get()方法獲取結(jié)果(會阻塞等待),或通過isDone()判斷任務(wù)是否完成。
特點:
支持獲取異步任務(wù)的返回值,但get()方法會阻塞,靈活性有限。
無法直接對結(jié)果進行鏈式處理(如任務(wù) A 完成后自動執(zhí)行任務(wù) B)。
三、基于 CompletableFuture 的異步(推薦,JDK 8+)
CompletableFuture是 JDK 8 引入的增強類,支持鏈式調(diào)用、異常處理、多任務(wù)組合等,是現(xiàn)代 Java 異步編程的核心。
1. 基本用法(無返回值)
2. 帶返回值的異步任務(wù)
3. 鏈式調(diào)用(任務(wù)依賴)
4. 多任務(wù)組合(并行執(zhí)行)
5. 異常處理
特點:
支持鏈式調(diào)用、結(jié)果合并、異常處理,無需手動管理線程池(默認使用ForkJoinPool)。
可靈活定制異步任務(wù)的依賴關(guān)系,適合復(fù)雜的異步場景。





暫無評論,快來評論吧!