Java實現(xiàn)任務(wù)超時處理方法
任務(wù)超時處理是比較常見的需求,比如在進行一些比較耗時的操作(如網(wǎng)絡(luò)請求)或者在占用一些比較寶貴的資源(如數(shù)據(jù)庫連接)時,我們通常需要給這些操作設(shè)置一個超時時間,當執(zhí)行時長超過設(shè)置的閾值的時候,就終止操作并回收資源。Java中對超時任務(wù)的處理有兩種方式:一種是基于異步任務(wù)結(jié)果的超時獲取,一種則是使用延時任務(wù)來終止超時操作。下文將詳細說明。
一、基于異步任務(wù)結(jié)果的超時獲取
基于異步任務(wù)結(jié)果的獲取通常是跟線程池一起使用的,我們向線程池提交任務(wù)時會返回一個Future對象,在調(diào)用Future的get方法時,可以設(shè)置一個超時時間,如果超過設(shè)置的時間任務(wù)還沒結(jié)束,就拋出異常。接下來看代碼:
public class FutureDemo { static ExecutorService executorService= Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors()*2); public static void main(String[] args) { Future<String> future = executorService.submit(new Callable<String>() { @Override public String call() { try { TimeUnit.SECONDS.sleep(10); } catch (InterruptedException e) { System.out.println("任務(wù)被中斷。"); } return "OK"; } }); try { String result = future.get(2, TimeUnit.SECONDS); } catch (InterruptedException |ExecutionException | TimeoutException e) { future.cancel(true); System.out.println("任務(wù)超時。"); }finally { System.out.println("清理資源。"); } }}
運行代碼,輸出如下:
二、使用延時任務(wù)來終止超時操作
還有一種實現(xiàn)任務(wù)超時處理的思路是在提交任務(wù)之前先設(shè)置一個定時器,這個定時器會在設(shè)置的時間間隔之后去取消任務(wù)。當然如果任務(wù)在規(guī)定的時間內(nèi)完成了,要記得取消定時器。首先來看一下我們的工作線程:
public class RunningTask { private volatile boolean isStop; public void stop(){ this.isStop=true; } public void doing() { int i=1; while (!isStop){ try { TimeUnit.SECONDS.sleep(1); } catch (InterruptedException e) { } } System.out.println("任務(wù)被中斷。"); } }
這個工作線程每隔一秒鐘會去檢查下isStop變量,因此我們可以通過isStop變量來取消任務(wù)。至于取消任務(wù)的邏輯我們放在了定時器里面,代碼如下:
public class CancelTask implements Runnable { private RunningTask runningTask; public CancelTask(RunningTask runningTask) { this.runningTask = runningTask; } @Override public void run() { runningTask.stop(); } }
可以看到,該定時器的作用就是在一定的時間之后去中斷工作線程的運行。接下來測試一下:
public class ScheduleDemo { static ScheduledExecutorService executorService= Executors.newScheduledThreadPool(Runtime.getRuntime().availableProcessors()*2); public static void main(String[] args) { RunningTask runningTask=new RunningTask(); ScheduledFuture<?> scheduledFuture = executorService.schedule(new CancelTask(runningTask), 3, TimeUnit.SECONDS); runningTask.doing(); if(!scheduledFuture.isDone()){ scheduledFuture.cancel(true); } } }
運行結(jié)果如下:
可以看到,任務(wù)在超時之后也可以被取消。
總結(jié)
以上所述是小編給大家介紹的Java實現(xiàn)任務(wù)超時處理方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
JAVAEE項目結(jié)構(gòu)以及并發(fā)隨想
每個代碼里面的工具都是工具,API是你最需要理解的,哪個好,哪個不好,沒有準確答案。 一切皆對象,對于Java來講是純粹的,代理是對象,反射是對象,對象是對象,基本數(shù)據(jù)類型不是對象。2016-04-04SpringBoot使用JTA實現(xiàn)對多數(shù)據(jù)源的事務(wù)管理
了解事務(wù)的都知道,在我們?nèi)粘i_發(fā)中單單靠事務(wù)管理就可以解決絕大多數(shù)問題了,但是為啥還要提出JTA這個玩意呢,到底JTA是什么呢?他又是具體來解決啥問題的呢?本文小編就給大家介紹一下如何在Spring Boot中使用JTA實現(xiàn)對多數(shù)據(jù)源的事務(wù)管理2023-11-11Jpa數(shù)據(jù)操作以及@Query和@Modifying注解使用方式
這篇文章主要介紹了Jpa數(shù)據(jù)操作以及@Query和@Modifying注解使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07如何在SpringBoot中添加攔截器忽略請求URL當中的指定字符串
這篇文章主要介紹了在SpringBoot中添加攔截器忽略請求URL當中的指定字符串,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08