溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Future怎么在Java與Scala中使用

發(fā)布時(shí)間:2021-01-16 10:13:11 來源:億速云 閱讀:117 作者:Leah 欄目:編程語言

Future怎么在Java與Scala中使用?很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

Future

很多同學(xué)可能會有疑問,F(xiàn)utrue跟異步編程有什么關(guān)系?從Future的表面意思是未來,一個(gè)Future對象可以看出一個(gè)將來得到的結(jié)果,這就和異步執(zhí)行的概念很像,你只管自己去執(zhí)行,只要將最終的結(jié)果傳達(dá)給我就行,線程不必一直暫停等待結(jié)果,可以在具體異步任務(wù)執(zhí)行的時(shí)候去執(zhí)行其他操作,舉個(gè)例子:

Future怎么在Java與Scala中使用

async work

我們現(xiàn)在在執(zhí)行做飯這么一個(gè)任務(wù),它需要煮飯,燒菜,擺置餐具等操作,如果我們通過異步這種概念去執(zhí)行這個(gè)任務(wù),比如煮飯可能需要比較久的時(shí)間,但煮飯這個(gè)過程又不需要我們管理,我們可以利用這段時(shí)間去燒菜,燒菜過程中也可能有空閑時(shí)間,我們可以去擺置餐具,當(dāng)電飯鍋通知我們飯燒好了,菜也燒好了,最后我們就可以開始吃飯了,所以說,上面的“煮飯 -> 飯”,“燒菜 -> 菜”都可以看成一個(gè)Future的過程。

Java中的Future

在Java的早期版本中,我們不能得到線程的執(zhí)行結(jié)果,不管是繼承Thread類還是實(shí)現(xiàn)Runnable接口,都無法獲取線程的執(zhí)行結(jié)果,所以我們只能在線程執(zhí)行的run方法里去做相應(yīng)的一些業(yè)務(wù)邏輯操作,但隨著Java5的發(fā)布,它為了我們帶來了Callable和Future接口,我們可以利用這兩個(gè)接口的特性來獲取線程的執(zhí)行結(jié)果。

Callable接口

通俗的講,Callable接口也是一個(gè)線程執(zhí)行類接口,那么它跟Runnable接口有什么區(qū)別呢?我們先來看看它們兩個(gè)的定義:

1.Callable接口:

@FunctionalInterface
public interface Callable<V> {
 /**
  * Computes a result, or throws an exception if unable to do so.
  *
  * @return computed result
  * @throws Exception if unable to compute a result
  */
 V call() throws Exception;
}

2.Runnable接口:

@FunctionalInterface
public interface Runnable {
 public abstract void run();
}

從上面的定義,我們可以看出,兩者最大的區(qū)別就是對應(yīng)的執(zhí)行方法是否有返回值。Callable接口中call方法具有返回值,這便是為什么我們可以通過Callable接口來得到一個(gè)線程執(zhí)行的返回值或者是異常信息。

Future接口

上面說到既然Callable接口能返回線程執(zhí)行的結(jié)果,那么為什么還需要Future接口呢?因?yàn)镃allable接口執(zhí)行的結(jié)果只是一個(gè)將來的結(jié)果值,我們?nèi)羰切枰玫骄唧w的結(jié)果就必須利用Future接口,另外Callable接口需要委托ExecutorService的submit提交任務(wù)去執(zhí)行,我們來看看它是如何定義的:

<T> Future<T> submit(Callable<T> task);
 public <T> Future<T> submit(Callable<T> task) {
  if (task == null) throw new NullPointerException();
  RunnableFuture<T> ftask = newTaskFor(task);
  execute(ftask);
  return ftask;
 }

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI