您好,登錄后才能下訂單哦!
小編這次要給大家分享的是Java多線程Callable和Future接口有什么區(qū)別,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
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<Integer> 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<Integer> { @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)容寫得不錯的話,可以把它分享出去給更多人看到。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。