1、Callable接口是什么?
? ? ? ? 是java.util.concurrent包下的一個(gè)函數(shù)式接口,用來創(chuàng)建線程的。返回結(jié)果是一個(gè)任務(wù),并可能拋出異常。
2、Callable接口和Runnable的區(qū)別呢?
? ??Callable可以有返回值,可以拋出異常,而Runnable正好相反
? ??Callable方法時(shí)call,而Runnable方法時(shí)run

3、FutureTask類
? ? api文檔翻譯如下:
?????一個(gè)可以取消的異步計(jì)算的類。這個(gè)類提供了 Future基實(shí)現(xiàn),用的方法啟動(dòng)和取消計(jì)算,查詢是否計(jì)算完成,并檢索結(jié)果。結(jié)果只能檢索時(shí),計(jì)算已完成的 get方法將阻塞;如果計(jì)算尚未完成。一旦計(jì)算完成,計(jì)算不能重新啟動(dòng)或取消(除非計(jì)算時(shí)使用 runAndReset())。
????一個(gè)FutureTask可以用來包裝Callable或Runnable對(duì)象。因?yàn)镕utureTask實(shí)現(xiàn)Runnable,一FutureTask可以提交執(zhí)行Executor。

異步調(diào)用,來處理一件比較消耗資源的方法,比如4個(gè)同學(xué),A算1+20,B算21+30,C算31*到40,D算41+50,是不是C的計(jì)算量有點(diǎn)大啊,那么開一個(gè)線程去計(jì)算C同學(xué)的任務(wù),然后等A/B/C 計(jì)算完成時(shí)再查詢是否計(jì)算完成。這樣的好處不會(huì)阻塞。
當(dāng)主線程需要執(zhí)行比較耗時(shí)的操作時(shí),但又不想阻塞主線程,可以創(chuàng)建一個(gè)線程去執(zhí)行這個(gè)操作在后臺(tái)完成,當(dāng)主線程需要這個(gè)線程運(yùn)行的結(jié)果或執(zhí)行狀態(tài)時(shí),再去獲取。
一般FutureTask比較耗時(shí),主線程完成自己的任務(wù)或需要時(shí)再去獲取。計(jì)算結(jié)果僅僅在計(jì)算完成時(shí)返回,若線程獲取時(shí)沒有計(jì)算完成,主線程會(huì)一直等待該線程計(jì)算完成。該計(jì)算一旦完成就不會(huì)再次執(zhí)行。
