您好,登錄后才能下訂單哦!
前言
之前連續寫了幾篇關于使用@Async實現異步調用的內容,也得到不少童鞋的反饋,其中問題比較多的就是關于返回Future的使用方法以及對異步執行的超時控制,所以這篇就來一起講講這兩個問題的處理。
如果您對于@Async注解的使用還不了解的話,可以看看之前的文章,具體如下:
定義異步任務
首先,我們先使用@Async注解來定義一個異步任務,這個方法返回Future類型,具體如下:
@Slf4j @Component public class Task { public static Random random = new Random(); @Async("taskExecutor") public Future<String> run() throws Exception { long sleep = random.nextInt(10000); log.info("開始任務,需耗時:" + sleep + "毫秒"); Thread.sleep(sleep); log.info("完成任務"); return new AsyncResult<>("test"); } }
Tips:什么是Future類型?
Future是對于具體的Runnable或者Callable任務的執行結果進行取消、查詢是否完成、獲取結果的接口。必要時可以通過get方法獲取執行結果,該方法會阻塞直到任務返回結果。
它的接口定義如下:
public interface Future<V> { boolean cancel(boolean mayInterruptIfRunning); boolean isCancelled(); boolean isDone(); V get() throws InterruptedException, ExecutionException; V get(long timeout, TimeUnit unit) throws InterruptedException, ExecutionException, TimeoutException; }
它聲明這樣的五個方法:
也就是說Future提供了三種功能:
測試執行與定義超時
在完成了返回Future的異步任務定義之后,我們來嘗試實現一個單元測試來使用這個Future完成任務的執行,比如:
@Slf4j @RunWith(SpringJUnit4ClassRunner.class) @SpringBootTest public class ApplicationTests { @Autowired private Task task; @Test public void test() throws Exception { Future<String> futureResult = task.run(); String result = futureResult.get(5, TimeUnit.SECONDS); log.info(result); } }
上面的代碼中,我們在get方法中還定義了該線程執行的超時時間,通過執行這個測試我們可以觀察到執行時間超過5秒的時候,這里會拋出超時異常,該執行線程就能夠因執行超時而釋放回線程池,不至于一直阻塞而占用資源。
完整示例:
讀者可以根據喜好選擇下面的兩個倉庫中查看Chapter4-1-4項目:
Github:https://github.com/dyc87112/SpringBoot-Learning/
Gitee:https://gitee.com/didispace/SpringBoot-Learning/
本地下載:http://xiazai.jb51.net/201805/yuanma/SpringBoot-Learning(jb51.net).rar
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。