小編這次要給大家分享的是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é)果。 FutureTaskresult =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)容寫得不錯的話,可以把它分享出去給更多人看到。