SpringBoot對Future模式的支持詳解

前言

專注于為中小企業(yè)提供成都網(wǎng)站制作、網(wǎng)站設計服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)扎賚特免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。

我們在實際項目中有些復雜運算、耗時操作,就可以利用多線程來充分利用CPU,提高系統(tǒng)吞吐量。SpringBoot對多線程支持非常好,對我們的開發(fā)非常便捷。

Future模式是多線程開發(fā)中非常常見的一種設計模式。核心思想是異步調(diào)用。當我們執(zhí)行一個方法時,方法中有多個耗時任務需要同時去做,而且又不著急等待這個結(jié)果時可以讓客戶端立即返回然后,后臺慢慢去計算任務。

當我們做一件事的時候需要等待,那么我們就可以在這個等待時間內(nèi)來去做其它事情,這樣就可以充分利用時間。比如我們點外賣,需要一段時間,那么我們在等外賣的時間里可以看點書,看個電影。這就是典型的Future模式。如果是普通模式的話,就是等外賣的時候就等外賣,外賣到了后再去看書,極大的浪費時間。

SpringBoot對Future模式支持非常好,只需要簡單的代碼就能實現(xiàn)。

1.Future的相關(guān)方法

  • boolean cancel(boolean mayInterruptIfRunning);//可以在任務執(zhí)行過程中取消任務
  • boolean isCancelled();//判斷Future任務是否取消
  • boolean isDone();//判斷任務是否完成
  • V get();//獲取任務最終結(jié)果,這是一個阻塞方法,會等待任務執(zhí)行好才會執(zhí)行后面的代碼
  • V get(long timeout, TimeUnit unit);//有等待時常的get方法,等待時間到了后仍然沒有計算完成,則拋異常

2.需要的注解

springboot 配置多線程需要兩個注解

1、@EnableAsync

在配置類中通過加@EnableAsync開啟對異步任務的支持
2、@Async

在需要執(zhí)行的方法上加@Async表明該方法是個異步方法,如果加在類級別上,則表明類所有的方法都是異步方法

3.配置代碼

@Configuration
@EnableAsync
public class AsyncConfig implements AsyncConfigurer {

 @Override
 public Executor getAsyncExecutor() {
 ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
 //核心線程數(shù)
 taskExecutor.setCorePoolSize(8);
 //最大線程數(shù)
 taskExecutor.setMaxPoolSize(16);
 //隊列大小
 taskExecutor.setQueueCapacity(100);
 taskExecutor.initialize();
 return taskExecutor;
 }
}

4.FutureService

@Service
public class FutureService {

 @Async
 public Future<String> futureTest() throws InterruptedException {
 System.out.println("任務執(zhí)行開始,需要:1000ms");
 for (int i = 0; i < 10; i++) {
  Thread.sleep(100);
  System.out.println("do:" + i);
 }
 System.out.println("完成任務");
 return new AsyncResult<>(Thread.currentThread().getName());
 }
}

【注】這里的方法自動被注入使用上文配置的ThreadPoolTaskExecutor

5.測試代碼

@Resource
private FutureService futureService;

@Test
public void futureTest() throws InterruptedException, ExecutionException {
 long start = System.currentTimeMillis();
 System.out.println("開始");
 //耗時任務
 Future<String> future = futureService.futureTest();
 //另外一個耗時任務
 Thread.sleep(500);
 System.out.println("另外一個耗時任務,需要500ms");

 String s = future.get();
 System.out.println("計算結(jié)果輸出:" + s);
 System.out.println("共耗時:" + (System.currentTimeMillis() - start));
}

6.運行結(jié)果

開始
2019-01-07 23:50:34.726 INFO 14648 --- [ main] o.s.s.concurrent.ThreadPoolTaskExecutor : Initializing ExecutorService
任務執(zhí)行開始,需要:1000ms
do:0
do:1
do:2
do:3
另外一個耗時任務,需要500ms
do:4
do:5
do:6
do:7
do:8
do:9
完成任務
計算結(jié)果輸出:ThreadPoolTaskExecutor-1
共耗時:1016

Process finished with exit code 0

本來需要至少1500ms 執(zhí)行的任務現(xiàn)在只需要1016ms,因為在執(zhí)行耗時任務1的同時也在執(zhí)行耗時任務2,兩個任務并行執(zhí)行,這就是future模式的好處,在等待時間內(nèi)去執(zhí)行其它任務,能夠充分利用時間

【注】本文基于SpringBoot 2.0

GitHub 連接

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對創(chuàng)新互聯(lián)的支持。

網(wǎng)頁標題:SpringBoot對Future模式的支持詳解
分享鏈接:http://bm7419.com/article26/jjepjg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供ChatGPT、用戶體驗響應式網(wǎng)站、微信小程序、微信公眾號、定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應式網(wǎng)站建設