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-04
Mybatis中foreach標(biāo)簽帶來(lái)的空格\換行\(zhòng)回車問(wèn)題及解決方案
這篇文章主要介紹了解決Mybatis中foreach標(biāo)簽帶來(lái)的空格,換行,回車問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
springmvc實(shí)現(xiàn)跨服務(wù)器文件上傳功能
這篇文章主要為大家詳細(xì)介紹了springmvc實(shí)現(xiàn)跨服務(wù)器文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08
Netty啟動(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-06
java學(xué)習(xí)筆記_關(guān)于字符串概述
下面小編就為大家?guī)?lái)一篇java學(xué)習(xí)筆記_關(guān)于字符串概述。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05
Spring生命周期回調(diào)與容器擴(kuò)展詳解
這篇文章主要介紹了Spring生命周期回調(diào)與容器擴(kuò)展詳解,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12
SpringBoot解決跨域請(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-06
Java單例模式利用HashMap實(shí)現(xiàn)緩存數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了Java單例模式利用HashMap實(shí)現(xiàn)緩存數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04

