真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java多線程Callable和Future接口有什么區(qū)別

小編這次要給大家分享的是Java多線程Callable和Future接口有什么區(qū)別,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

公司主營業(yè)務:成都做網(wǎng)站、成都網(wǎng)站設(shè)計、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)公司推出新密免費做網(wǎng)站回饋大家。

Runnable是執(zhí)行工作的獨立任務,但是不返回任何值。如果我們希望任務完成之后有返回值,可以實現(xiàn)Callable接口。在JavaSE5中引入的Callable是一個具有類型參數(shù)的范型,他的類型參數(shù)方法表示為方法call()而不是run()中返回的值,并且必須使用ExecutorService.submint()方法進行調(diào)用。

代碼如下

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;
/*
 * 一、創(chuàng)建執(zhí)行線程的方式三:實現(xiàn) Callable 接口。 相較于實現(xiàn) Runnable 接口的方式,方法可以有返回值,并且可以拋出異常。
 *
 * 二、執(zhí)行 Callable 方式,需要 FutureTask 實現(xiàn)類的支持,用于接收運算結(jié)果。 FutureTask 是 Future 接口的實現(xiàn)類
 */
public class TestCallable {
 
  public static void main(String[] args) {
    ThreadDemo td =new ThreadDemo();
 
    //1.執(zhí)行 Callable 方式,需要 FutureTask 實現(xiàn)類的支持,用于接收運算結(jié)果。
    FutureTask result =new FutureTask<>(td);
 
    new Thread(result).start();
 
    //2.接收線程運算后的結(jié)果
    try {
      Integer sum = result.get(); //FutureTask 可用于 閉鎖 類似于CountDownLatch的作用,在所有的線程沒有執(zhí)行完成之后這里是不會執(zhí)行的
      System.out.println(sum);
      System.out.println("------------------------------------");
    }catch (InterruptedException | ExecutionException e) {
      e.printStackTrace();
    }
  }
}
class ThreadDemo implements Callable {
  @Override
  public Integer call() throws Exception {
    int sum = 0;
 
    for (int i = 0; i <= 100000; i++) {
      sum += i;
    }
    return sum;
  }
}

綜上例子可以看到: Callable 和 Future接口的區(qū)別

(1)Callable規(guī)定的方法是call(),而Runnable規(guī)定的方法是run().

(2)Callable的任務執(zhí)行后可返回值,而Runnable的任務是不能返回值的。

(3)call()方法可拋出異常,而run()方法是不能拋出異常的。

(4)運行Callable任務可拿到一個Future對象, Future表示異步計算的結(jié)果。

它提供了檢查計算是否完成的方法,以等待計算的完成,并檢索計算的結(jié)果。

通過Future對象可了解任務執(zhí)行情況,可取消任務的執(zhí)行,還可獲取任務執(zhí)行的結(jié)果。

Callable是類似于Runnable的接口,實現(xiàn)Callable接口的類和實現(xiàn)Runnable的類都是可被其它線程執(zhí)行的任務。

看完這篇關(guān)于Java多線程Callable和Future接口有什么區(qū)別的文章,如果覺得文章內(nèi)容寫得不錯的話,可以把它分享出去給更多人看到。


網(wǎng)頁標題:Java多線程Callable和Future接口有什么區(qū)別
網(wǎng)頁地址:http://weahome.cn/article/piscci.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部