亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java中CompleteFuture與Future的區(qū)別小結(jié)

 更新時(shí)間:2023年12月20日 08:31:08   作者:有夢想的攻城獅  
本文主要介紹了java中CompleteFuture與Future的區(qū)別小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

CompleteFuture的介紹

CompletableFuture是Java 8提供的一種基于Future的異步編程的實(shí)現(xiàn)。它不僅可以代表異步計(jì)算的結(jié)果,還能夠定義它完成之后的回調(diào)函數(shù)。它的實(shí)現(xiàn)在java.util.concurrent.CompletableFuture的包內(nèi)。

CompletableFuture的實(shí)現(xiàn)涉及到JDK 8的幾個(gè)新特性,如Lambda、Stream、線程池等,它允許把任務(wù)池、線程池和阻塞隊(duì)列組合在一起,使得開發(fā)者可以更加簡單地實(shí)現(xiàn)異步編程,對程序的執(zhí)行性能也帶來了一定的提升。

與Future相比,CompletableFuture的優(yōu)勢在于:

  • 可以直接對多個(gè)任務(wù)進(jìn)行鏈?zhǔn)?、組合等處理,而不需要借助并發(fā)工具類。
  • 實(shí)現(xiàn)了對任務(wù)編排的能力,可以輕松地組織不同任務(wù)的運(yùn)行順序、規(guī)則以及方式。

CompleteFuture的特點(diǎn)

CompletableFuture的特點(diǎn)主要包括異步執(zhí)行、鏈?zhǔn)讲僮骱挽`活性強(qiáng)。

  • 異步執(zhí)行:CompletableFuture允許任務(wù)在后臺線程中異步執(zhí)行,不會阻塞主線程,提高了應(yīng)用程序的響應(yīng)性和性能。
  • 鏈?zhǔn)讲僮鳎篊ompletableFuture支持鏈?zhǔn)讲僮鳎梢苑奖愕靥幚砣蝿?wù)的依賴關(guān)系和結(jié)果轉(zhuǎn)換。
  • 靈活性強(qiáng):相比于傳統(tǒng)的Future接口,CompletableFuture更加靈活和強(qiáng)大,提供了豐富的方法來處理異步操作和多個(gè)任務(wù)的結(jié)果。

CompleteFuture的應(yīng)用場景

CompletableFuture的應(yīng)用場景主要包括異步編程、任務(wù)組合和并發(fā)編程。

  • 異步編程:在需要執(zhí)行耗時(shí)操作的情況下,使用CompletableFuture可以實(shí)現(xiàn)異步執(zhí)行,避免阻塞主線程,提高程序的響應(yīng)性和性能。
  • 任務(wù)組合:CompletableFuture支持鏈?zhǔn)讲僮?,可以將多個(gè)異步任務(wù)組合在一起,按照指定的順序和邏輯執(zhí)行,實(shí)現(xiàn)任務(wù)的依賴關(guān)系和結(jié)果轉(zhuǎn)換。
  • 并發(fā)編程:在多線程環(huán)境下,CompletableFuture可以方便地處理多個(gè)任務(wù)的結(jié)果,避免線程間的競爭和同步問題,提高并發(fā)編程的效率和可靠性。

CompletableFuture的優(yōu)缺點(diǎn)

CompletableFuture的優(yōu)點(diǎn)主要包括簡潔易用、支持異步編程、任務(wù)組合和并發(fā)編程等。它提供了一種簡潔的方式來處理異步計(jì)算和任務(wù)組合,使得異步編程更加容易和高效。

然而,CompletableFuture也存在一些缺點(diǎn),例如:

  • 無法對多個(gè)任務(wù)進(jìn)行鏈?zhǔn)秸{(diào)用:如果希望在計(jì)算任務(wù)完成后執(zhí)行特定動作,比如發(fā)郵件,但CompletableFuture卻沒有提供這樣的能力。
  • 無法組合多個(gè)任務(wù):如果運(yùn)行了10個(gè)任務(wù),并期望在它們?nèi)繄?zhí)行結(jié)束后執(zhí)行特定動作,那么在CompletableFuture中這是無能為力的。
  • 沒有異常處理:CompletableFuture接口中沒有關(guān)于異常處理的方法。

Future的介紹

Future是Java中用于異步計(jì)算的一個(gè)接口。它提供了一種方式,允許將一個(gè)耗時(shí)的計(jì)算任務(wù)放到另一個(gè)線程中執(zhí)行,而主線程可以繼續(xù)處理其他任務(wù)。

在Future接口中,通常包含一些方法,如isDone()、get()、cancel()等。isDone()方法用于檢查Future是否已經(jīng)完成,get()方法用于獲取Future的結(jié)果,cancel()方法用于取消Future的計(jì)算任務(wù)。

使用Future接口可以實(shí)現(xiàn)異步計(jì)算,提高程序的執(zhí)行效率。當(dāng)需要執(zhí)行一個(gè)耗時(shí)的計(jì)算任務(wù)時(shí),可以創(chuàng)建一個(gè)Future對象,然后將該對象傳遞給異步線程執(zhí)行。異步線程執(zhí)行完成后,可以通過Future對象獲取計(jì)算結(jié)果。

Future的特點(diǎn)

Future的特點(diǎn)主要有以下幾個(gè)方面:

  • 表示異步操作未完成時(shí)的狀態(tài):Future對象可以表示一個(gè)異步操作是否完成,如果異步操作未完成,F(xiàn)uture對象的狀態(tài)為未完成,如果異步操作完成,F(xiàn)uture對象的狀態(tài)為已完成。
  • 可以用來獲取異步操作完成后返回的結(jié)果:通過Future對象提供的get方法,可以獲取異步操作完成后返回的結(jié)果。
  • 不提供直接的方式來添加回調(diào)函數(shù):Future不提供一種直接的方式來添加回調(diào)函數(shù),處理操作完成后的結(jié)果或異常。
  • 只能表示異步任務(wù)是否完成,而不能手動觸發(fā)任務(wù)的完成或組合多個(gè)任務(wù):Future只能表示異步任務(wù)是否完成,而不能手動觸發(fā)任務(wù)的完成或組合多個(gè)任務(wù)。

Future的應(yīng)用場景

Future的應(yīng)用場景主要在并發(fā)編程中,當(dāng)我們需要用到非阻塞的模型時(shí),F(xiàn)uture就顯得尤為重要。

在Java多線程的三種實(shí)現(xiàn)中,無論是繼承Thread類還是實(shí)現(xiàn)Runnable接口,都是異步的,并且主調(diào)函數(shù)無法獲取到返回值。而Future則可以接收多線程的執(zhí)行結(jié)果。具體來說,F(xiàn)uture接收一個(gè)可能還沒有完成的異步任務(wù)的結(jié)果,針對這個(gè)結(jié)果可以添加Callable以便任務(wù)執(zhí)行成功或失敗后作出相應(yīng)的操作。

采用Future修改的異步方法,在每次被異步調(diào)用以后會馬上返回(無論異步方法體是否執(zhí)行完成),F(xiàn)uture就會監(jiān)聽異步任務(wù)執(zhí)行狀態(tài)(成功、失?。鹊綀?zhí)行完成以后,就能通過Future.get()方法獲取到異步返回的結(jié)果。也就是說,如果批量調(diào)用采用Future修飾的異步方法,程序不會阻塞等待,然后再遍歷Future列表,即可獲取到所有的異步結(jié)果(Future的內(nèi)部機(jī)制是等所有的異步任務(wù)完成了才進(jìn)行遍歷)。這種請求耗時(shí)只會略大于耗時(shí)最長的一個(gè)Future修飾的方法。

Future的優(yōu)缺點(diǎn)

Future的優(yōu)點(diǎn)主要包括:

  • 異步處理:Future允許將耗時(shí)的計(jì)算任務(wù)放到另一個(gè)線程中執(zhí)行,不會阻塞主線程,提高了程序的執(zhí)行效率。
  • 鏈?zhǔn)讲僮?/strong>:Future支持鏈?zhǔn)讲僮?,可以方便地處理任?wù)的依賴關(guān)系和結(jié)果轉(zhuǎn)換。

然而,F(xiàn)uture也存在一些缺點(diǎn):

  • 阻塞獲取結(jié)果:當(dāng)需要獲取Future的結(jié)果時(shí),如果計(jì)算還沒有完成,會導(dǎo)致程序阻塞。這可能會影響程序的性能和響應(yīng)性。
  • 無法添加回調(diào)函數(shù):Future不提供一種直接的方式來添加回調(diào)函數(shù),處理操作完成后的結(jié)果或異常。這使得在異步操作完成后,無法直接進(jìn)行特定的處理。

CompletableFuture和Future的區(qū)別

CompletableFuture和Future的區(qū)別主要體現(xiàn)在以下幾個(gè)方面:

  • 功能區(qū)別 :Future只能用于獲取異步計(jì)算的結(jié)果,而CompletableFuture除了能獲取異步計(jì)算的結(jié)果外,還可以用于組合多個(gè)異步任務(wù),處理異常情況,以及在任務(wù)完成時(shí)執(zhí)行回調(diào)函數(shù)等。
  • 阻塞區(qū)別 :Future的get方法是阻塞的,如果異步計(jì)算沒有完成,它會一直等待直到計(jì)算完成。而CompletableFuture的get方法也是阻塞的,但是它可以設(shè)置超時(shí)時(shí)間,如果在指定的時(shí)間內(nèi)計(jì)算沒有完成,它會拋出TimeoutException異常。
  • 異常處理區(qū)別 :Future的異常處理比較麻煩,需要在任務(wù)執(zhí)行時(shí)捕獲異常,然后將異常封裝到Future對象中返回。而CompletableFuture的異常處理比較簡單,可以使用exceptionally方法或handle方法來處理異常情況。
  • 組合任務(wù)區(qū)別 :Future不支持組合多個(gè)異步任務(wù),需要使用ExecutorService的submit方法來提交多個(gè)任務(wù),并使用Future對象來獲取每個(gè)任務(wù)的結(jié)果。而CompletableFuture支持組合多個(gè)異步任務(wù),可以使用thenCompose、thenCombine、thenAcceptBoth等方法來組合多個(gè)任務(wù)。

CompletableFuture和Future的關(guān)聯(lián)關(guān)系

CompletableFuture和Future之間存在關(guān)聯(lián)關(guān)系,因?yàn)镃ompletableFuture實(shí)現(xiàn)了Future接口。這意味著CompletableFuture可以作為Future使用,同時(shí)它還提供了更多功能,如鏈?zhǔn)讲僮鳌惓L幚砗徒M合任務(wù)等。

CompletableFuture在內(nèi)部使用了一個(gè)子線程來執(zhí)行任務(wù),并且提供了異步計(jì)算的結(jié)果。當(dāng)異步計(jì)算完成時(shí),CompletableFuture會自動將結(jié)果設(shè)置為已完成狀態(tài),并且可以通過get方法獲取結(jié)果。

與Future相比,CompletableFuture提供了更多的功能和靈活性。它支持鏈?zhǔn)讲僮?,可以將多個(gè)異步任務(wù)組合在一起,并且可以在任務(wù)完成后執(zhí)行特定的回調(diào)函數(shù)。此外,CompletableFuture還提供了異常處理機(jī)制,可以捕獲和處理任務(wù)執(zhí)行過程中拋出的異常。

因此,CompletableFuture是Future的擴(kuò)展和增強(qiáng),它提供了更多的功能和靈活性,適用于需要處理異步計(jì)算和組合多個(gè)任務(wù)的場景。

CompletableFuture和Future的使用示例

CompletableFuture使用示例

以下是一個(gè)使用CompletableFuture的示例:

import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;

public class CompletableFutureExample {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> {
            // 模擬耗時(shí)操作
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return "Hello, World!";
        });

        // 獲取異步計(jì)算的結(jié)果
        String result = future.get();
        System.out.println(result);
    }
}

在這個(gè)示例中,我們使用CompletableFuture的supplyAsync方法創(chuàng)建了一個(gè)異步任務(wù),該任務(wù)會返回一個(gè)字符串"Hello, World!"。然后,我們使用get方法獲取異步計(jì)算的結(jié)果,并將其打印出來。這個(gè)示例演示了如何使用CompletableFuture來執(zhí)行異步計(jì)算并獲取結(jié)果。

Future使用示例

以下是一個(gè)使用Java Future的示例:

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

public class FutureExample {
    public static void main(String[] args) throws Exception {
        ExecutorService executor = Executors.newSingleThreadExecutor();

        // 提交任務(wù)并獲取Future對象
        Future<String> future = executor.submit(() -> {
            // 模擬耗時(shí)操作
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return "Hello, World!";
        });

        // 獲取異步計(jì)算的結(jié)果
        String result = future.get();
        System.out.println(result);

        // 關(guān)閉ExecutorService
        executor.shutdown();
    }
}

在這個(gè)示例中,我們使用ExecutorService的submit方法提交了一個(gè)異步任務(wù),該任務(wù)會返回一個(gè)字符串"Hello, World!"。然后,我們使用Future的get方法獲取異步計(jì)算的結(jié)果,并將其打印出來。最后,我們關(guān)閉了ExecutorService以釋放資源。這個(gè)示例演示了如何使用Java Future來執(zhí)行異步計(jì)算并獲取結(jié)果。

CompletableFuture應(yīng)用步驟

在項(xiàng)目中使用CompletableFuture,可以按照以下步驟進(jìn)行:

  • 導(dǎo)入CompletableFuture類:首先,需要在項(xiàng)目中導(dǎo)入CompletableFuture類,以便使用其功能。
  • 創(chuàng)建異步任務(wù):使用CompletableFuture的靜態(tài)方法supplyAsync或runAsync來創(chuàng)建異步任務(wù)。supplyAsync方法接受一個(gè)Supplier接口的實(shí)現(xiàn)類作為參數(shù),用于定義異步任務(wù)的邏輯。runAsync方法接受一個(gè)Runnable接口的實(shí)現(xiàn)類作為參數(shù),用于定義異步任務(wù)的邏輯。
  • 鏈?zhǔn)讲僮鳎菏褂肅ompletableFuture的thenApply、thenAccept、thenRun等方法來鏈?zhǔn)讲僮鳟惒饺蝿?wù)。這些方法接受一個(gè)Function、Consumer或Runnable接口的實(shí)現(xiàn)類作為參數(shù),用于定義鏈?zhǔn)讲僮鞯倪壿嫛?/li>
  • 異常處理:使用CompletableFuture的exceptionally方法來處理異步任務(wù)中拋出的異常。exceptionally方法接受一個(gè)Function接口的實(shí)現(xiàn)類作為參數(shù),用于定義異常處理的邏輯。
  • 獲取結(jié)果:使用CompletableFuture的get方法來獲取異步計(jì)算的結(jié)果。get方法會阻塞當(dāng)前線程,直到異步計(jì)算完成并返回結(jié)果。

以下是一個(gè)簡單的示例代碼,演示了如何在項(xiàng)目中使用CompletableFuture:

import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;

public class CompletableFutureExample {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> {
            // 模擬耗時(shí)操作
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return "Hello, World!";
        }).thenApply(result -> {
            // 鏈?zhǔn)讲僮鳎簩Y(jié)果進(jìn)行處理
            return result.toUpperCase();
        }).thenAccept(result -> {
            // 鏈?zhǔn)讲僮鳎簩Y(jié)果進(jìn)行處理并輸出到控制臺
            System.out.println(result);
        });

        // 獲取異步計(jì)算的結(jié)果(如果需要)
        future.get();
    }
}

在上面的示例中,我們首先使用CompletableFuture的supplyAsync方法創(chuàng)建了一個(gè)異步任務(wù),該任務(wù)會返回一個(gè)字符串"Hello, World!"。然后,我們使用thenApply方法對結(jié)果進(jìn)行鏈?zhǔn)讲僮鳎瑢⒔Y(jié)果轉(zhuǎn)換為大寫字母。接著,我們使用thenAccept方法對結(jié)果進(jìn)行鏈?zhǔn)讲僮鳎瑢⒔Y(jié)果輸出到控制臺。最后,我們使用get方法獲取異步計(jì)算的結(jié)果(如果需要)。

到此這篇關(guān)于java中CompleteFuture與Future的區(qū)別小結(jié)的文章就介紹到這了,更多相關(guān)java CompleteFuture與Future內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot2.3新特性優(yōu)雅停機(jī)詳解

    SpringBoot2.3新特性優(yōu)雅停機(jī)詳解

    這篇文章主要介紹了SpringBoot2.3新特性優(yōu)雅停機(jī)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • Mybatis中的resultType和resultMap使用

    Mybatis中的resultType和resultMap使用

    這篇文章主要介紹了Mybatis中的resultType和resultMap使用,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • java環(huán)境變量的配置方法圖文詳解【win10環(huán)境為例】

    java環(huán)境變量的配置方法圖文詳解【win10環(huán)境為例】

    這篇文章主要介紹了java環(huán)境變量的配置方法,結(jié)合圖文形式詳細(xì)分析了win10環(huán)境下java環(huán)境變量的配置方法與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2020-04-04
  • 淺談一下Java線程組ThreadGroup

    淺談一下Java線程組ThreadGroup

    ThreadGroup是為了方便線程管理出現(xiàn)了,可以統(tǒng)一設(shè)定線程組的一些屬性,比如setDaemon,設(shè)置未處理異常的處理方法,設(shè)置統(tǒng)一的安全策略等等,需要的朋友可以參考下
    2023-05-05
  • java微信掃描公眾號二維碼實(shí)現(xiàn)登陸功能

    java微信掃描公眾號二維碼實(shí)現(xiàn)登陸功能

    這篇文章主要為大家詳細(xì)介紹了PHP微信掃描公眾號二維碼實(shí)現(xiàn)登陸功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Spring?Boot集成RabbitMQ以及隊(duì)列模式操作

    Spring?Boot集成RabbitMQ以及隊(duì)列模式操作

    RabbitMQ是實(shí)現(xiàn)AMQP(高級消息隊(duì)列協(xié)議)的消息中間件的一種,下面這篇文章主要給大家介紹了關(guān)于Spring?Boot集成RabbitMQ以及隊(duì)列模式操作的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • 如何利用Jackson序列化忽略指定類型的屬性詳解

    如何利用Jackson序列化忽略指定類型的屬性詳解

    這篇文章主要給大家介紹了關(guān)于如何利用Jackson序列化忽略指定類型的屬性,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • Spring Boot常見外部配置文件方式詳析

    Spring Boot常見外部配置文件方式詳析

    這篇文章主要給大家介紹了關(guān)于Spring Boot常見外部配置文件方式的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用Spring Boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 關(guān)于Spring MVC框架中攔截器Interceptor的使用解讀

    關(guān)于Spring MVC框架中攔截器Interceptor的使用解讀

    這篇文章主要介紹了關(guān)于Spring MVC框架中攔截器Interceptor的使用,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 詳解java 中的CAS與ABA

    詳解java 中的CAS與ABA

    這篇文章主要介紹了java 中的CAS與ABA的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下
    2021-05-05

最新評論