您好,登錄后才能下訂單哦!
這篇文章主要介紹“JDK8新特性java.util.function-Function接口怎么使用”的相關(guān)知識(shí),小編通過(guò)實(shí)際案例向大家展示操作過(guò)程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“JDK8新特性java.util.function-Function接口怎么使用”文章能幫助大家解決問(wèn)題。
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ù)入口,真正了解一下。
name | type | description |
---|---|---|
Consumer | Consumer< T > | 接收T對(duì)象,不返回值 |
Predicate | Predicate< T > | 接收T對(duì)象并返回boolean |
Function | Function< T, R > | 接收T對(duì)象,返回R對(duì)象 |
Supplier | Supplier< T > | 提供T對(duì)象(例如工廠),不接收值 |
UnaryOperator | UnaryOperator | 接收T對(duì)象,返回T對(duì)象 |
BinaryOperator | BinaryOperator | 接收兩個(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 ‘@FunctionalInterface’ annotation; FunctionalInterfaceTest is not a functional interface錯(cuò)誤.
//將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
字符串長(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)。
免責(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)容。