溫馨提示×

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

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

JDK8新特性java.util.function-Function接口怎么使用

發(fā)布時(shí)間:2023-05-06 11:22:00 來(lái)源:億速云 閱讀:95 作者:iii 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹“JDK8新特性java.util.function-Function接口怎么使用”的相關(guān)知識(shí),小編通過(guò)實(shí)際案例向大家展示操作過(guò)程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“JDK8新特性java.util.function-Function接口怎么使用”文章能幫助大家解決問(wèn)題。

JDK8新特性-java.util.function-Function接口

14年,Oracle公司如期發(fā)布了Java 8正式版?,F(xiàn)如今4年過(guò)去了,終于鼓起勇氣認(rèn)真對(duì)待它,就好似雖然認(rèn)識(shí)了好幾年的伙伴,突然感覺(jué)要成為情侶的感覺(jué)……

JDK 1.8 API包含了很多內(nèi)建的函數(shù)式接口,在老Java中常用到的比如Comparator或者Runnable接口,這些接口都增加了@FunctionalInterface注解以便能用在lambda上。

現(xiàn)如今,我們則從Function常用函數(shù)入口,真正了解一下。

nametypedescription
ConsumerConsumer< T >接收T對(duì)象,不返回值
PredicatePredicate< T >接收T對(duì)象并返回boolean
FunctionFunction< T, R >接收T對(duì)象,返回R對(duì)象
SupplierSupplier< T >提供T對(duì)象(例如工廠),不接收值
UnaryOperatorUnaryOperator接收T對(duì)象,返回T對(duì)象
BinaryOperatorBinaryOperator接收兩個(gè)T對(duì)象,返回T對(duì)象

標(biāo)注為FunctionalInterface的接口被稱(chēng)為函數(shù)式接口,該接口只能有一個(gè)自定義方法,但是可以包括從object類(lèi)繼承而來(lái)的方法。

如果一個(gè)接口只有一個(gè)方法,則編譯器會(huì)認(rèn)為這就是一個(gè)函數(shù)式接口。

是否是一個(gè)函數(shù)式接口,需要注意的有以下幾點(diǎn):

  • 該注解只能標(biāo)記在”有且僅有一個(gè)抽象方法”的接口上。

  • JDK8接口中的靜態(tài)方法和默認(rèn)方法,都不算是抽象方法。

  • 接口默認(rèn)繼承java.lang.Object,所以如果接口顯示聲明覆蓋了Object中方法,那么也不算抽象方法。

  • 該注解不是必須的,如果一個(gè)接口符合”函數(shù)式接口”定義,那么加不加該注解都沒(méi)有影響。加上該注解能夠更好地讓編譯器進(jìn)行檢查。如果編寫(xiě)的不是函數(shù)式接口,但是加上了@FunctionInterface,那么編譯器會(huì)報(bào)錯(cuò)。

  • 在一個(gè)接口中定義兩個(gè)自定義的方法,就會(huì)產(chǎn)生Invalid &lsquo;@FunctionalInterface&rsquo; annotation; FunctionalInterfaceTest is not a functional interface錯(cuò)誤.

Function常用方法&&實(shí)踐

//將Function對(duì)象應(yīng)用到輸入的參數(shù)上,然后返回計(jì)算結(jié)果。
R apply(T t);
//返回一個(gè)先執(zhí)行當(dāng)前函數(shù)對(duì)象apply方法再執(zhí)行after函數(shù)對(duì)象apply方法的函數(shù)對(duì)象。
default <V> Function<T, V> andThen(Function<? super R, ? extends V> after) {
        Objects.requireNonNull(after);
        return (T t) -> after.apply(apply(t));
    }
//返回一個(gè)先執(zhí)行before函數(shù)對(duì)象apply方法再執(zhí)行當(dāng)前函數(shù)對(duì)象apply方法的函數(shù)對(duì)象
default <V> Function<V, R> compose(Function<? super V, ? extends T> before) {
        Objects.requireNonNull(before);
        return (V v) -> apply(before.apply(v));
    }

compose 和 andThen 的不同之處是函數(shù)執(zhí)行的順序不同。

compose 函數(shù)先執(zhí)行參數(shù),然后執(zhí)行調(diào)用者,而 andThen 先執(zhí)行調(diào)用者,然后再執(zhí)行參數(shù)。

public static void main(String[] args) {
        Function<Integer, Integer> name = e -> e * 2;
        Function<Integer, Integer> square = e -> e * e;
        int value = name.andThen(square).apply(3);
        System.out.println("andThen value=" + value);
        int value2 = name.compose(square).apply(3);
        System.out.println("compose value2=" + value2);
        //返回一個(gè)執(zhí)行了apply()方法之后只會(huì)返回輸入?yún)?shù)的函數(shù)對(duì)象
        Object identity = Function.identity().apply("huohuo");
        System.out.println(identity);
    }

直接看結(jié)果:

andThen value=36
compose value2=18
huohuo

apply基本應(yīng)用

字符串長(zhǎng)度記錄返回

public class MyFunction implements Function<String,Integer>{

    @Override
    public Integer apply(String s) {
        return s.length();
    }
}

返回兩個(gè)字符串的連接,BiFunction與Function的不同就是傳入兩個(gè)參數(shù),依舊返回一個(gè)值。

public class MyBiFunction implements BiFunction<String, String, String> {
    @Override
    public String apply(String s, String s2) {
        return s+";"+s2;
    }
}

最后調(diào)用結(jié)果:

private static String hello = "Nice to meet you";
    private static String name = "my name is huohuo";

    public static void main(String[] args) {
        MyFunction myFunction = new MyFunction();
        MyBiFunction biFunction = new MyBiFunction();
        int num = myFunction.apply(hello);
        String valueBi = biFunction.apply(hello, name);
        //hello長(zhǎng)度返回
        System.out.println(num);
        //語(yǔ)句整合返回
        System.out.println(valueBi);
    }

返回值:

16
Nice to meet you;my name is huohuo

其實(shí)使用的過(guò)程感覺(jué)這些都無(wú)所必要,但是對(duì)于新特性以及代碼規(guī)范而言,即使是簡(jiǎn)易代碼,也有了一個(gè)整合的過(guò)程。

Function簡(jiǎn)單實(shí)踐僅此為止,下篇文章講述Predicate的使用。

關(guān)于“JDK8新特性java.util.function-Function接口怎么使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

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

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

jdk
AI