Java中的FutureTask實現(xiàn)異步任務(wù)代碼實例
FutureTask實現(xiàn)異步任務(wù)
FutureTask 的執(zhí)行結(jié)果和出現(xiàn)異常的異常對象都會被放到outcome對象中,通過get()方法返回。
1.測試future任務(wù)正常返回
public class T2 { ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNamePrefix("thread-start-runner").build(); ExecutorService taskExe = new ThreadPoolExecutor(10, 20, 800L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<>(100), namedThreadFactory); private static final Logger LOG = LoggerFactory.getLogger(T2.class); @Test public void test2() { List<FutureTask<Integer>> taskList = new ArrayList<>(); for (int i = 0; i < 10; i++) { final int a = i; FutureTask<Integer> futureTask = new FutureTask<>(() -> { LOG.info("正在進行第" + a + "個任務(wù)"); Thread.sleep(3000); return 1; }); taskList.add(futureTask); //異步執(zhí)行 taskExe.submit(futureTask); } LOG.info("任務(wù)添加完成"); int count = 0; try { for (FutureTask<Integer> task : taskList) { /* FutureTask執(zhí)行的結(jié)果會放入它的私有變量outcome中,其他線程直接調(diào)用futureTask.get()去讀取該變量即可 會阻塞直到單個任務(wù)執(zhí)行完畢 * */ Integer value = task.get(); LOG.info("value:" + value); count += value; } } catch (InterruptedException e) { LOG.error("線程執(zhí)行被中斷", e); } catch (ExecutionException e) { LOG.error("線程執(zhí)行出現(xiàn)異常", e); } taskExe.shutdown(); LOG.info("count:" + count); }```
執(zhí)行結(jié)果:正常累加。
2.測試future任務(wù)異常返回,通過get()方法拿到異常
@Test public void test3() { List<FutureTask<Integer>> taskList = new ArrayList<>(); for (int i = 0; i < 10; i++) { final int a = i; FutureTask<Integer> futureTask = new FutureTask<>(() -> { LOG.info("正在進行第" + a + "個任務(wù)"); int v=1/0; return 1; }); taskList.add(futureTask); //異步執(zhí)行 taskExe.submit(futureTask); } LOG.info("任務(wù)添加完成"); int count = 0; try { for (FutureTask<Integer> task : taskList) { /* FutureTask執(zhí)行的結(jié)果會放入它的私有變量outcome中(包括異常),其他線程直接調(diào)用futureTask.get()去讀取該變量即可 會阻塞直到單個任務(wù)執(zhí)行完畢 * */ Integer value = task.get(); LOG.info("value:" + value); count += value; } } catch (InterruptedException e) { LOG.error("線程執(zhí)行被中斷", e); } catch (ExecutionException e) { LOG.error("線程執(zhí)行出現(xiàn)異常", e); } taskExe.shutdown(); LOG.info("count:" + count); }
執(zhí)行結(jié)果:捕獲到異常。
3.callable出現(xiàn)異常,不進行g(shù)et()
@Test public void test4() { List<FutureTask<Integer>> taskList = new ArrayList<>(); for (int i = 0; i < 10; i++) { final int a = i; FutureTask<Integer> futureTask = new FutureTask<>(() -> { LOG.info("正在進行第" + a + "個任務(wù)"); int v = 1 / 0; return 1; }); taskList.add(futureTask); //異步執(zhí)行 taskExe.submit(futureTask); } LOG.info("任務(wù)添加完成"); taskExe.shutdown(); }
執(zhí)行結(jié)果:沒有拋出異常。
到此這篇關(guān)于Java中的FutureTask實現(xiàn)異步任務(wù)代碼實例的文章就介紹到這了,更多相關(guān)FutureTask實現(xiàn)異步任務(wù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Java代碼進行因數(shù)分解和求最小公倍數(shù)的示例
這篇文章主要介紹了使用Java代碼進行因數(shù)分解和求最小公倍數(shù)的示例,都是基于最基礎(chǔ)的算法原理實現(xiàn),需要的朋友可以參考下2015-11-11Java?synchronized底層實現(xiàn)原理以及鎖優(yōu)化
Synchronized是Java中解決并發(fā)問題的一種最常用的方法,也是最簡單的一種方法,下面這篇文章主要給大家介紹了關(guān)于Java?synchronized底層實現(xiàn)原理以及鎖優(yōu)化的相關(guān)資料,需要的朋友可以參考下2022-02-02