Java多線程之Callable接口的實現

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;

/*
 * 1、建立執行線程的方式三:實現 Callable 接口。 相較於實現 Runnable 接口的方式,方法能夠有返回值,而且能夠拋出異常。
 * 
 * 2、執行 Callable 方式,須要 FutureTask 實現類的支持,用於接收運算結果。  FutureTask 是  Future 接口的實現類
 */
public class TestCallable {

    public static void main(String[] args) {
        ThreadDemo td = new ThreadDemo();

        //1.執行 Callable 方式,須要 FutureTask 實現類的支持,用於接收運算結果。
        FutureTask<Integer> result = new FutureTask<>(td);

        new Thread(result).start();

        //2.接收線程運算後的結果
        try {
            Integer sum = result.get();  //FutureTask 可用於 閉鎖 相似於CountDownLatch的做用,在全部的線程沒有執行完成以後這裏是不會執行的
            System.out.println(sum);
            System.out.println("------------------------------------");
        } catch (InterruptedException | ExecutionException e) {
            e.printStackTrace();
        }
    }

}

class ThreadDemo implements Callable<Integer> {

    @Override
    public Integer call() throws Exception {
        int sum = 0;

        for (int i = 0; i <= 100000; i++) {
            sum += i;
        }

        return sum;
    }

}

 綜上例子能夠看到: Callable 和 Future接口的區別java

  1.   (1)Callable規定的方法是call(),而Runnable規定的方法是run(). 
  2.   (2)Callable的任務執行後可返回值,而Runnable的任務是不能返回值的。  
  3.   (3)call()方法可拋出異常,而run()方法是不能拋出異常的。 
  4.   (4)運行Callable任務可拿到一個Future對象, Future表示異步計算的結果。 
  5.   它提供了檢查計算是否完成的方法,以等待計算的完成,並檢索計算的結果。 
  6.   經過Future對象可瞭解任務執行狀況,可取消任務的執行,還可獲取任務執行的結果。 
  7. Callable是相似於Runnable的接口,實現Callable接口的類和實現Runnable的類都是可被其它線程執行的任務。 
相關文章
相關標籤/搜索