java 多線程 傳回值 Callable

來源:互聯網
上載者:User
 package cn;import java.util.concurrent.*;
import java.util.Date;
import java.util.List;
import java.util.ArrayList;/**
 * * Java線程:有傳回值的線程
 * @author wb_qiuquan.ying
 */
@SuppressWarnings("unchecked")
public class Test {
 @SuppressWarnings("rawtypes")
 public static void main(String[] args) throws ExecutionException,
   InterruptedException {
  int sizeNum = 5;
  // 建立一個線程池
  ExecutorService pool =
Executors.newFixedThreadPool(sizeNum);
  // 建立多個有傳回值的任務
  List<Future> list = new ArrayList<Future>();
  for (int i = 0; i < sizeNum; i++) {
//   Callable c = new MyCallable(i + " ");也可以這樣寫,運行結果一樣
   MyCallable c = new MyCallable(i + " ");
   
   // 執行任務並擷取Future對象
   Future f = pool.submit(c);
   System.out.println("線程運行中此線程的值是:" + f.get().toString());
   list.add(f);
  }
  // 關閉線程池 pool.shutdown();
  // 擷取所有並發任務的運行結果
  System.out.println("");
  for (Future f : list) {
   // 從Future對象上擷取任務的傳回值,並輸出到控制台
   System.out.println("關閉線程池後,各個線程的值:"+ f.get().toString());
  }
  
  System.exit(0);
 }
}class MyCallable implements
Callable<Object> { private String taskNum; MyCallable(String taskNum) {
  this.taskNum = taskNum;
 }
    //call()方法
 public Object call()
throws Exception {
  System.out.println(">>>" + taskNum + "call()方法任務啟動");
  Date dateTmp1 = new Date();
  Thread.sleep(1000);
  Date dateTmp2 = new Date();
  long time = dateTmp2.getTime() - dateTmp1.getTime();
  System.out.println(">>>" + taskNum + "任務終止");
  return "線程"+taskNum + "返回啟動並執行時間【" + time + "毫秒】";
 }
}  //輸出>>>0 call()方法任務啟動
>>>0 任務終止
線程運行中此線程的值是:線程0 返回啟動並執行時間【1000毫秒】
>>>1 call()方法任務啟動
>>>1 任務終止
線程運行中此線程的值是:線程1 返回啟動並執行時間【1000毫秒】
>>>2 call()方法任務啟動
>>>2 任務終止
線程運行中此線程的值是:線程2 返回啟動並執行時間【1000毫秒】
>>>3 call()方法任務啟動
>>>3 任務終止
線程運行中此線程的值是:線程3 返回啟動並執行時間【1000毫秒】
>>>4 call()方法任務啟動
>>>4 任務終止
線程運行中此線程的值是:線程4 返回啟動並執行時間【1000毫秒】關閉線程池後,各個線程的值:線程0 返回啟動並執行時間【1000毫秒】
關閉線程池後,各個線程的值:線程1 返回啟動並執行時間【1000毫秒】
關閉線程池後,各個線程的值:線程2 返回啟動並執行時間【1000毫秒】
關閉線程池後,各個線程的值:線程3 返回啟動並執行時間【1000毫秒】
關閉線程池後,各個線程的值:線程4 返回啟動並執行時間【1000毫秒】
 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.