Java中callable的實(shí)現(xiàn)原理
在Java并發(fā)編程中,Runnable、Callable、Future、RunnableFuture 和 FutureTask 這些接口和類都是為了支持異步任務(wù)執(zhí)行和結(jié)果獲取而設(shè)計(jì)的。下面分別說(shuō)明它們的設(shè)計(jì)原理并提供使用范例。
Runnable Interface
Runnable 是 Java 中最基本的線程任務(wù)接口,它只包含一個(gè) run() 方法,用于定義線程需要執(zhí)行的任務(wù)。
public interface Runnable { void run(); } // 使用示例 class MyRunnable implements Runnable { @Override public void run() { System.out.println("Running a task in a thread..."); } public static void main(String[] args) { Thread t = new Thread(new MyRunnable()); t.start(); } }
Callable Interface
Callable 接口擴(kuò)展了 Runnable 的功能,它提供了有返回值的任務(wù),并且可以拋出異常。通過(guò)實(shí)現(xiàn) call() 方法,我們可以創(chuàng)建一個(gè)能返回結(jié)果的任務(wù)。
import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; public class MyCallable implements Callable<Integer> { @Override public Integer call() throws Exception { int result = someComputation(); // 假設(shè)這是個(gè)計(jì)算方法 return result; } public static void main(String[] args) throws ExecutionException, InterruptedException { MyCallable callable = new MyCallable(); FutureTask<Integer> futureTask = new FutureTask<>(callable); Thread t = new Thread(futureTask); t.start(); // 獲取線程執(zhí)行完成后的結(jié)果 Integer computedResult = futureTask.get(); System.out.println("Computed result: " + computedResult); } }
Future Interface
Future 接口代表了一個(gè)異步計(jì)算的結(jié)果,提供了檢查計(jì)算是否完成、阻塞等待計(jì)算結(jié)果以及獲取計(jì)算結(jié)果的方法。
import java.util.concurrent.Future; // 通常不直接實(shí)現(xiàn) Future 接口,而是由其他類如 FutureTask 實(shí)現(xiàn) public class FutureExample { public void executeTaskWithFuture() throws ExecutionException, InterruptedException { ExecutorService executor = Executors.newSingleThreadExecutor(); Future<Integer> future = executor.submit(new MyCallable()); // 可以做其他事情,然后... // 當(dāng)需要結(jié)果時(shí),調(diào)用 get() 方法會(huì)阻塞直到結(jié)果準(zhǔn)備好 Integer result = future.get(); System.out.println("Result from Future: " + result); // 關(guān)閉線程池 executor.shutdown(); } }
RunnableFuture Interface
RunnableFuture 同時(shí)繼承了 Runnable 和 Future 接口,這意味著它是一個(gè)可運(yùn)行的任務(wù),同時(shí)也能作為 Future 來(lái)獲取結(jié)果。
import java.util.concurrent.RunnableFuture; // 不直接實(shí)現(xiàn) RunnableFuture,而是使用 FutureTask 等已實(shí)現(xiàn)它的類 class MyRunnableFuture extends FutureTask<Integer> { public MyRunnableFuture(Callable<Integer> callable) { super(callable); } public void customMethod() { // 可以添加額外的自定義方法 } }
FutureTask Class
FutureTask 類實(shí)現(xiàn)了 RunnableFuture 接口,因此它可以被提交給 Executor 執(zhí)行,同時(shí)又可以作為 Future 來(lái)查詢結(jié)果或取消任務(wù)。
import java.util.concurrent.FutureTask; public class FutureTaskExample { public static void main(String[] args) throws ExecutionException, InterruptedException { // 創(chuàng)建一個(gè) FutureTask,傳入 Callable 對(duì)象 FutureTask<Integer> futureTask = new FutureTask<>(new MyCallable()); // 創(chuàng)建一個(gè)線程來(lái)執(zhí)行這個(gè)任務(wù) Thread thread = new Thread(futureTask); thread.start(); // 或者將 FutureTask 提交到 ExecutorService // ExecutorService executor = Executors.newSingleThreadExecutor(); // executor.execute(futureTask); // 獲取結(jié)果 Integer result = futureTask.get(); System.out.println("Result from FutureTask: " + result); } }
總結(jié)來(lái)說(shuō),當(dāng)需要在線程中執(zhí)行帶有返回值的任務(wù)時(shí),通常會(huì)選擇 Callable 接口配合 FutureTask 類或者直接將 Callable 任務(wù)提交給 ExecutorService。FutureTask 能夠方便地將 Runnable 或 Callable 的任務(wù)與 Future 結(jié)果機(jī)制相結(jié)合,使得主線程能夠獲取到異步計(jì)算的結(jié)果。
到此這篇關(guān)于Java中callable的實(shí)現(xiàn)原理的文章就介紹到這了,更多相關(guān)Java callable內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java 詳細(xì)講解線程安全與同步附實(shí)例與注釋
線程安全是多線程編程時(shí)的計(jì)算機(jī)程序代碼中的一個(gè)概念。在擁有共享數(shù)據(jù)的多條線程并行執(zhí)行的程序中,線程安全的代碼會(huì)通過(guò)同步機(jī)制保證各個(gè)線程都可以正常且正確的執(zhí)行,不會(huì)出現(xiàn)數(shù)據(jù)污染等意外情況2022-04-04Mybatis中foreach標(biāo)簽帶來(lái)的空格\換行\(zhòng)回車(chē)問(wèn)題及解決方案
這篇文章主要介紹了解決Mybatis中foreach標(biāo)簽帶來(lái)的空格,換行,回車(chē)問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04springmvc實(shí)現(xiàn)跨服務(wù)器文件上傳功能
這篇文章主要為大家詳細(xì)介紹了springmvc實(shí)現(xiàn)跨服務(wù)器文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08Netty啟動(dòng)流程注冊(cè)多路復(fù)用源碼解析
這篇文章主要介紹了Netty啟動(dòng)流程注冊(cè)多路復(fù)用源碼分析,繼續(xù)分析channel是如何注冊(cè)到selector中的,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-03-03解決FontConfiguration.getVersion報(bào)空指針異常的問(wèn)題
這篇文章主要介紹了解決FontConfiguration.getVersion報(bào)空指針異常的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06java學(xué)習(xí)筆記_關(guān)于字符串概述
下面小編就為大家?guī)?lái)一篇java學(xué)習(xí)筆記_關(guān)于字符串概述。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05Spring生命周期回調(diào)與容器擴(kuò)展詳解
這篇文章主要介紹了Spring生命周期回調(diào)與容器擴(kuò)展詳解,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12SpringBoot解決跨域請(qǐng)求攔截問(wèn)題代碼實(shí)例
這篇文章主要介紹了SpringBoot解決跨域請(qǐng)求攔截代碼實(shí)例,在微服務(wù)開(kāi)發(fā)中,一個(gè)系統(tǒng)包含多個(gè)微服務(wù),會(huì)存在跨域請(qǐng)求的場(chǎng)景。 本文講解SpringBoot解決跨域請(qǐng)求攔截的問(wèn)題。,需要的朋友可以參考下2019-06-06Java單例模式利用HashMap實(shí)現(xiàn)緩存數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了Java單例模式利用HashMap實(shí)現(xiàn)緩存數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04