欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
Java線(xiàn)程(六):Callable和Future
 Callable接口類(lèi)似于Runnable,從名字就可以看出來(lái)了,但是Runnable不會(huì )返回結果,并且無(wú)法拋出返回結果的異常,而Callable功能更強大一些,被線(xiàn)程執行后,可以返回值,這個(gè)返回值可以被Future拿到,也就是說(shuō),Future可以拿到異步執行任務(wù)的返回值,下面來(lái)看一個(gè)簡(jiǎn)單的例子:

  1. public class CallableAndFuture {  
  2.     public static void main(String[] args) {  
  3.         Callable<Integer> callable = new Callable<Integer>() {  
  4.             public Integer call() throws Exception {  
  5.                 return new Random().nextInt(100);  
  6.             }  
  7.         };  
  8.         FutureTask<Integer> future = new FutureTask<Integer>(callable);  
  9.         new Thread(future).start();  
  10.         try {  
  11.             Thread.sleep(5000);// 可能做一些事情  
  12.             System.out.println(future.get());  
  13.         } catch (InterruptedException e) {  
  14.             e.printStackTrace();  
  15.         } catch (ExecutionException e) {  
  16.             e.printStackTrace();  
  17.         }  
  18.     }  
  19. }  
        FutureTask實(shí)現了兩個(gè)接口,Runnable和Future,所以它既可以作為Runnable被線(xiàn)程執行,又可以作為Future得到Callable的返回值,那么這個(gè)組合的使用有什么好處呢?假設有一個(gè)很耗時(shí)的返回值需要計算,并且這個(gè)返回值不是立刻需要的話(huà),那么就可以使用這個(gè)組合,用另一個(gè)線(xiàn)程去計算返回值,而當前線(xiàn)程在使用這個(gè)返回值之前可以做其它的操作,等到需要這個(gè)返回值時(shí),再通過(guò)Future得到,豈不美哉!這里有一個(gè)Future模式的介紹:http://caterpillar.onlyfun.net/Gossip/DesignPattern/FuturePattern.htm。

        下面來(lái)看另一種方式使用Callable和Future,通過(guò)ExecutorService的submit方法執行Callable,并返回Future,代碼如下:

  1. public class CallableAndFuture {  
  2.     public static void main(String[] args) {  
  3.         ExecutorService threadPool = Executors.newSingleThreadExecutor();  
  4.         Future<Integer> future = threadPool.submit(new Callable<Integer>() {  
  5.             public Integer call() throws Exception {  
  6.                 return new Random().nextInt(100);  
  7.             }  
  8.         });  
  9.         try {  
  10.             Thread.sleep(5000);// 可能做一些事情  
  11.             System.out.println(future.get());  
  12.         } catch (InterruptedException e) {  
  13.             e.printStackTrace();  
  14.         } catch (ExecutionException e) {  
  15.             e.printStackTrace();  
  16.         }  
  17.     }  
  18. }  
        代碼是不是簡(jiǎn)化了很多,ExecutorService繼承自Executor,它的目的是為我們管理Thread對象,從而簡(jiǎn)化并發(fā)編程,Executor使我們無(wú)需顯示的去管理線(xiàn)程的生命周期,是JDK 5之后啟動(dòng)任務(wù)的首選方式。

        執行多個(gè)帶返回值的任務(wù),并取得多個(gè)返回值,代碼如下:

  1. public class CallableAndFuture {  
  2.     public static void main(String[] args) {  
  3.         ExecutorService threadPool = Executors.newCachedThreadPool();  
  4.         CompletionService<Integer> cs = new ExecutorCompletionService<Integer>(threadPool);  
  5.         for(int i = 1; i < 5; i ) {  
  6.             final int taskID = i;  
  7.             cs.submit(new Callable<Integer>() {  
  8.                 public Integer call() throws Exception {  
  9.                     return taskID;  
  10.                 }  
  11.             });  
  12.         }  
  13.         // 可能做一些事情  
  14.         for(int i = 1; i < 5; i ) {  
  15.             try {  
  16.                 System.out.println(cs.take().get());  
  17.             } catch (InterruptedException e) {  
  18.                 e.printStackTrace();  
  19.             } catch (ExecutionException e) {  
  20.                 e.printStackTrace();  
  21.             }  
  22.         }  
  23.     }  
  24. }        

        其實(shí)也可以不使用CompletionService,可以先創(chuàng )建一個(gè)裝Future類(lèi)型的集合,用Executor提交的任務(wù)返回值添加到集合中,最后便利集合取出數據,代碼略。

本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
【第77題】JAVA高級技術(shù)-多線(xiàn)程11(創(chuàng )建線(xiàn)程的5種方式)
Future和Callable的使用總結
java多線(xiàn)程、線(xiàn)程池的實(shí)現
線(xiàn)程池:Execution框架
Java異步編程接口:Callable和Future | Aoho''s Blog
java線(xiàn)程管理利器:java.util.current的用法舉例
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久