Callable Future 以及CompletionService

來源:互聯網
上載者:User

java5線程庫中,使用Callable提交任務,可以獲得任務的運行完後的一個傳回值。使用線程池的submit方法提交Callable任務,submit方法將返回一個Future對象,此對象的get方法是線程阻塞的,直到任務運行結束後才會返回任務的傳回值。

 

多個任務提交到線程池後,想要多個擷取任務的運行完後的結果,可使用CompletionService類,此類可以擷取按執行完順序返回的結果。

下面是小樣本:

  ExecutorService pool2=Executors.newFixedThreadPool(10);
  CompletionService<String> completionService=new ExecutorCompletionService<String>(pool2);
  for(int i=0;i<10;i++){
   final int index=i;
   completionService.submit(new Callable<String>() {

    public String call() throws Exception {
     Thread.sleep(10);
     return index+"";
    }
   });
  }
  for(int i=0;i<10;i++){
   try {
    System.out.println(completionService.take().get());
   } catch (InterruptedException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   } catch (ExecutionException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.