欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot的異步任務(wù):無返回值和有返回值問題

 更新時間:2023年07月20日 09:33:49   作者:kailly235  
這篇文章主要介紹了springboot的異步任務(wù):無返回值和有返回值問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

springboot異步任務(wù):無返回值和有返回值

在想要異步執(zhí)行的方法上加上@Async注解,在controller上加上@EnableAsync,即可。

注:這里的異步方法,只能在本類之外調(diào)用,在本類調(diào)用是無效的。

無返回值的異步任務(wù)

service實現(xiàn)部分:

@Service
public class AsyncService {
? ? @Async //想要異步執(zhí)行的方法上加@Async 注解
? ? public void doNoReturn(){
? ? ? ? try {
? ? ? ? ? ? // 這個方法執(zhí)行需要三秒
? ? ? ? ? ? Thread.sleep(3000);
? ? ? ? ? ? System.out.println("方法執(zhí)行結(jié)束" + new Date());
? ? ? ? } catch (InterruptedException e) {
? ? ? ? ? ? e.printStackTrace();
? ? }
}

controller調(diào)用部分:

@RestController
@EnableAsync//調(diào)用異步任務(wù)的controller上加@EnableAsync注解
public class AsyncController {
? ? @Autowired
? ? private AsyncService asyncService;
? ? @RequestMapping(value = "/hello",method = RequestMethod.GET)
? ? public String testAsyncNoRetrun(){
? ? ? ? long start = System.currentTimeMillis();
? ? ? ? ?asyncService.doNoReturn();
? ? ? ? ?return String.format("任務(wù)執(zhí)行成功,耗時{%s}", System.currentTimeMillis() - start);
? ? }

輸出:

任務(wù)執(zhí)行成功,耗時{4}

可見testAsyncNoRetrun()方法中 調(diào)用doNoReturn(),沒等doNoReturn()執(zhí)行完即返回。

有返回值的異步任務(wù)

有返回值的異步任務(wù)方法需要用Futrue變量把返回值封裝起來。

service實現(xiàn)部分:

@Async
?public Future<String> doReturn(int i){
? ? ? ? try {
? ? ? ? ? ? // 這個方法需要調(diào)用500毫秒
? ? ? ? ? ? Thread.sleep(500);
? ? ? ? } catch (InterruptedException e) {
? ? ? ? ? ? e.printStackTrace();
? ? ? ? }
? ? ? ? // 消息匯總
? ? ? ? return new AsyncResult<>(String.format("這個是第{%s}個異步調(diào)用的證書", i));
}

讀取的時候要批量讀取不能單獨讀取。

controller調(diào)用部分:

@GetMapping("/hi")
? ? public Map<String, Object> testAsyncReturn() throws ExecutionException, InterruptedException {
? ? ? ? long start = System.currentTimeMillis();
? ? ? ? Map<String, Object> map = new HashMap<>();
? ? ? ? List<Future<String>> futures = new ArrayList<>();
? ? ? ? for (int i = 0; i < 10; i++) {
? ? ? ? ? ? Future<String> future = asyncService.doReturn(i);
? ? ? ? ? ? futures.add(future);
? ? ? ? }
? ? ? ? List<String> response = new ArrayList<>();
? ? ? ? for (Future future : futures) {
? ? ? ? ? ? String string = (String) future.get();
? ? ? ? ? ? response.add(string);
? ? ? ? }
? ? ? ? map.put("data", response);
? ? ? ? map.put("消耗時間", String.format("任務(wù)執(zhí)行成功,耗時{%s}毫秒", System.currentTimeMillis() - start));
? ? ? ? return map;
}

在瀏覽器輸入地址:http://localhost:8080/hi

結(jié)果如下: 耗時500多毫秒的意思代表,springboot自帶異步任務(wù)線程池是小于10的大小的

{"data":["這個是第{0}個異步調(diào)用的證書","這個是第{1}個異步調(diào)用的證書","這個是第{2}個異步調(diào)用的證書","這個是第{3}個異步調(diào)用的證書","這個是第{4}個異步調(diào)用的證書","這個是第{5}個異步調(diào)用的證書","這個是第{6}個異步調(diào)用的證書","這個是第{7}個異步調(diào)用的證書","這個是第{8}個異步調(diào)用的證書","這個是第{9}個異步調(diào)用的證書"],"消耗時間":"任務(wù)執(zhí)行成功,耗時{508}毫秒"}

springboot的異步任務(wù)(帶返回值和不帶返回值的處理)

注意:在用異步任務(wù)之前先給啟動類加@EnableAsync這個注解

新建異步任務(wù)包和在包里面建異步任務(wù)類

As.java異步類

package com.example.demo.async;
import org.springframework.scheduling.annotation.Async;
import org.springframework.scheduling.annotation.AsyncResult;
import org.springframework.stereotype.Component;
import java.util.concurrent.Future;
//注意:1、要把異步任務(wù)寫進一個類里面而不能直接寫在controller中
//      2、如果需要拿到結(jié)果,則需要在調(diào)用處判斷全部的task.isDone()來確定異步任務(wù)的完成
@Component
//異步類注解,表明整個類的方法都是異步方法,如果把這個注解加在某一個方法上而不是某一個類則表明僅僅是這個方法才是異步方法
@Async
public class As {
    //下面是3個異步任務(wù)(不帶返回值的)
    public void task1() throws InterruptedException {
        long begin=System.currentTimeMillis();
        Thread.sleep(3000l);
        long end=System.currentTimeMillis();
        System.out.println("任務(wù)1耗時"+(end-begin));
    }
    public void task2() throws InterruptedException {
        long begin=System.currentTimeMillis();
        Thread.sleep(2000l);
        long end=System.currentTimeMillis();
        System.out.println("任務(wù)2耗時"+(end-begin));
    }
    public void task3() throws InterruptedException {
        long begin=System.currentTimeMillis();
        Thread.sleep(1000l);
        long end=System.currentTimeMillis();
        System.out.println("任務(wù)3耗時"+(end-begin));
    }
    //下面是3個異步任務(wù)(帶返回值的,可以在調(diào)用出取地返回值)
    public Future<String> task4() throws InterruptedException {
        long begin=System.currentTimeMillis();
        Thread.sleep(3000l);
        long end=System.currentTimeMillis();
        return new AsyncResult<String>("任務(wù)4耗時"+(end-begin));
    }
    public Future<String> task5() throws InterruptedException {
        long begin=System.currentTimeMillis();
        Thread.sleep(2000l);
        long end=System.currentTimeMillis();
        return new AsyncResult<String>("任務(wù)5耗時"+(end-begin));
    }
    public Future<String> task6() throws InterruptedException {
        long begin=System.currentTimeMillis();
        Thread.sleep(1000l);
        long end=System.currentTimeMillis();
        return new AsyncResult<String>("任務(wù)6耗時"+(end-begin));
    }
}

controller測試控制器

package com.example.demo.controller;
import com.example.demo.async.As;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
@RestController
public class He {
	//注入異步類
    @Autowired
    private As as;
    //測試異步任務(wù)沒帶返回值的,直接主線程瞬間就通過了
    @RequestMapping("/as")
    public Object as() throws InterruptedException {
        long begin=System.currentTimeMillis();
        as.task1();
        as.task2();
        as.task3();
        long end=System.currentTimeMillis();
        return "總耗時+"+(end-begin);
    }
    //測試異步任務(wù)帶返回值的,總耗時是最慢的那個任務(wù)的耗時
    @RequestMapping("/asHava")
    public Object ash() throws InterruptedException, ExecutionException {
        long begin=System.currentTimeMillis();
        Future<String> task4=as.task4();
        Future<String> task5=as.task5();
        Future<String> task6=as.task6();
        //先小堵塞主線程一會,用以拿到異步任務(wù)返回值
        while (!(task4.isDone()&&task5.isDone()&&task6.isDone())){
        }
        long end=System.currentTimeMillis();
        //取得異步任務(wù)的返回值并查看總耗時
        return "總耗時+"+(end-begin)+"   task4結(jié)果:"+task4.get()+"  task5結(jié)果:"+task5.get()+"  task6結(jié)果:"+task6.get();
        //結(jié)果是3s左右,因為進入接口,三個異步任務(wù)瞬間開啟,再瞬間到while這兒堵起
        //由于三個異步任務(wù)幾乎是同時開啟的,所以等最慢的那個異步任務(wù)完成以后,肯定所有的異步任務(wù)都完成了
        //所以while這時才都為true,那么放開while,所以結(jié)果就是最慢的那個異步任務(wù)的時間
        //如果說不用這種異步取值而用同步的話,那么時間就是1+2+3就是6s左右,而不是最慢的那個任務(wù)的時間
    }
}

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 劍指Offer之Java算法習(xí)題精講鏈表專題篇

    劍指Offer之Java算法習(xí)題精講鏈表專題篇

    跟著思路走,之后從簡單題入手,反復(fù)去看,做過之后可能會忘記,之后再做一次,記不住就反復(fù)做,反復(fù)尋求思路和規(guī)律,慢慢積累就會發(fā)現(xiàn)質(zhì)的變化
    2022-03-03
  • 從最基本的Java工程搭建SpringMVC+SpringDataJPA+Hibernate

    從最基本的Java工程搭建SpringMVC+SpringDataJPA+Hibernate

    本文會介紹從一個最基本的java工程,到Web工程,到集成Spring、SpringMVC、SpringDataJPA+Hibernate,本文介紹的非常詳細,具有參考借鑒價值,感興趣的朋友一起學(xué)習(xí)吧
    2016-05-05
  • Feign如何實現(xiàn)第三方的HTTP請求

    Feign如何實現(xiàn)第三方的HTTP請求

    這篇文章主要介紹了Feign如何實現(xiàn)第三方的HTTP請求,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • SpringBoot中接收POST參數(shù)的幾種方式詳解

    SpringBoot中接收POST參數(shù)的幾種方式詳解

    這篇文章主要介紹了SpringBoot中接收POST參數(shù)的幾種方式,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • 詳解Java虛擬機管理的內(nèi)存運行時數(shù)據(jù)區(qū)域

    詳解Java虛擬機管理的內(nèi)存運行時數(shù)據(jù)區(qū)域

    這篇文章主要介紹了詳解Java虛擬機管理的內(nèi)存運行時數(shù)據(jù)區(qū)域的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • Spring實例化bean過程解析及完整代碼示例

    Spring實例化bean過程解析及完整代碼示例

    這篇文章主要介紹了Spring實例化bean過程解析及完整代碼示例,簡單分析實例化bean過程并且分享了相關(guān)實例,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • SpringBoot、mybatis返回樹結(jié)構(gòu)的數(shù)據(jù)實現(xiàn)

    SpringBoot、mybatis返回樹結(jié)構(gòu)的數(shù)據(jù)實現(xiàn)

    本文主要介紹了SpringBoot、mybatis返回樹結(jié)構(gòu)的數(shù)據(jù)實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • Spring實戰(zhàn)之清除緩存操作示例

    Spring實戰(zhàn)之清除緩存操作示例

    這篇文章主要介紹了Spring實戰(zhàn)之清除緩存操作,結(jié)合實例形式詳細分析了spring清除緩存操作具體步驟、配置、領(lǐng)域模型及相關(guān)使用技巧,需要的朋友可以參考下
    2020-01-01
  • Java實現(xiàn)非阻塞式服務(wù)器的示例代碼

    Java實現(xiàn)非阻塞式服務(wù)器的示例代碼

    這篇文章主要為大家詳細介紹了如何利用Java實現(xiàn)一個簡單的非阻塞式服務(wù)器,文中的示例代碼講解詳細,具有一定的學(xué)習(xí)價值,需要的可以參考一下
    2023-05-05
  • intellij idea中spring boot properties文件不能自動提示問題解決

    intellij idea中spring boot properties文件不能自動提示問題解決

    這篇文章主要介紹了intellij idea中spring boot properties文件不能自動提示問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02

最新評論