日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【转载】Callable、FutureTask中阻塞超时返回的坑点

發布時間:2024/10/12 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【转载】Callable、FutureTask中阻塞超时返回的坑点 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

本文轉載自:http://www.cnblogs.com/starcrm/p/5010863.html

案例1:

package com.net.thread.future;import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.FutureTask; import java.util.concurrent.TimeUnit;/*** @author * @Time:2017年8月18日 上午10:49:07* @version 1.0* @description*/ import java.util.concurrent.ExecutionException;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;import java.util.concurrent.FutureTask;import java.util.concurrent.TimeUnit;import java.util.concurrent.TimeoutException;public class FutureTaskExample {public static void main(String[] args) {MyCallable callable1 = new MyCallable(1000);MyCallable callable2 = new MyCallable(5000);FutureTask<String> futureTask1 = new FutureTask<String>(callable1);FutureTask<String> futureTask2 = new FutureTask<String>(callable2);ExecutorService executor = Executors.newFixedThreadPool(2);executor.execute(futureTask1);executor.execute(futureTask2);while (true) {try {if(futureTask1.isDone() && futureTask2.isDone()){System.out.println("Done");//shut down executor service executor.shutdown();return;}if(!futureTask1.isDone()){//阻塞futureTask1System.out.println("FutureTask1 output="+futureTask1.get());}if(!futureTask2.isDone()){//阻塞futureTask2System.out.println("FutureTask2 output="+futureTask2.get(1000,TimeUnit.MILLISECONDS));}} catch (InterruptedException | ExecutionException e) {e.printStackTrace();}catch(Exception e){//do nothing }}}static class MyCallable implements Callable<String> {private long waitTime;public MyCallable(int timeInMillis){this.waitTime=timeInMillis;}@Overridepublic String call() throws Exception {Thread.sleep(waitTime);return Thread.currentThread().getName();}}}

運行結果很簡單,必須是:

FutureTask1 output=pool-1-thread-1
FutureTask2 output=pool-1-thread-2
Done

?

案例2:

package com.net.thread.future;import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.FutureTask; import java.util.concurrent.TimeUnit;/*** @author * @Time:2017年8月18日 上午10:49:07* @version 1.0* @description*/ public class FutureTaskExample2 {public static void main(String[] args) {MyCallable callable1 = new MyCallable(1000);MyCallable callable2 = new MyCallable(5000);FutureTask<String> futureTask1 = new FutureTask<String>(callable1);FutureTask<String> futureTask2 = new FutureTask<String>(callable2);ExecutorService executor = Executors.newFixedThreadPool(2);executor.execute(futureTask1);executor.execute(futureTask2);while (true) {try {if(futureTask1.isDone() && futureTask2.isDone()){System.out.println("Done");//shut down executor service executor.shutdown();return;}if(!futureTask1.isDone()){//阻塞futureTask1System.out.println("FutureTask1 output="+futureTask1.get());}System.out.println("Waiting for FutureTask2 to complete");String s = futureTask2.get(1000, TimeUnit.MILLISECONDS); //阻塞500毫秒if(s !=null){System.out.println("FutureTask2 output="+s);}else{System.out.println("FutureTask2 output is null");}} catch (InterruptedException | ExecutionException e) {e.printStackTrace();}catch(Exception e){//do nothing } }}static class MyCallable implements Callable<String> {private long waitTime;public MyCallable(int timeInMillis){this.waitTime=timeInMillis;}@Overridepublic String call() throws Exception {Thread.sleep(waitTime);return Thread.currentThread().getName();}}}

運行結果:

FutureTask1 output=pool-1-thread-1
Waiting for FutureTask2 to complete
Waiting for FutureTask2 to complete
Waiting for FutureTask2 to complete
Waiting for FutureTask2 to complete
FutureTask2 output=pool-1-thread-2
Done

?

?

說明:

1、get()方法用來獲取執行結果,這個方法會產生阻塞,會一直等到任務執行完畢才返回;

2、get(long timeout, TimeUnit unit)用來獲取執行結果,如果超過指定時間,直接結束執行下面的代碼;如果是在循環中,則跳出本次循環進行下一次輪訓(continue功能類似)。

?

轉載于:https://www.cnblogs.com/chen1-kerr/p/7388725.html

總結

以上是生活随笔為你收集整理的【转载】Callable、FutureTask中阻塞超时返回的坑点的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。