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-11
Java?synchronized底層實現(xiàn)原理以及鎖優(yōu)化
Synchronized是Java中解決并發(fā)問題的一種最常用的方法,也是最簡單的一種方法,下面這篇文章主要給大家介紹了關(guān)于Java?synchronized底層實現(xiàn)原理以及鎖優(yōu)化的相關(guān)資料,需要的朋友可以參考下2022-02-02

