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





暫無(wú)評(píng)論,快來(lái)評(píng)論吧!