Java8_Function和BiFunction

Function

  1. Function作為一個函數(shù)式接口,主要方法apply接收一個參數(shù),返回一個值
@FunctionalInterface
public interface Function<T, R> {

    /**
     * Applies this function to the given argument.
     *
     * @param t the function argument
     * @return the function result
     */
    R apply(T t);
}

首先我們來寫一個計算數(shù)字的方法

public int compute(int a, Function<Integer, Integer> function) {
    int result = function.apply(a);
    return result;
}

然后我們調(diào)用這個方法

test.compute(5,value -> value * value) //25 計算平方
test.compute(5,value -> value + value) //10 求和
test.compute(5,value -> value - 2) //3  

可以看到我們定義一個方法就可以實現(xiàn)多種功能,這就是前面說過的Lambda表達(dá)式傳遞的是一種行為,我們把想要做的事在調(diào)用的時候,以一種行為的方式傳遞進(jìn)來,程序讀起來也更加直觀

  1. Function compose方法

compose方法是一個默認(rèn)方法,這個方法接收一個function作為參數(shù),將參數(shù)function執(zhí)行的結(jié)果作為參數(shù)給調(diào)用的function,以此來實現(xiàn)兩個function組合的功能。

public interface Function<T, R> {
    default <V> Function<V, R> compose(Function<? super V, ? extends T> before) {
        Objects.requireNonNull(before);
        return (V v) -> apply(before.apply(v));
    }
}

下面我們來舉例看一下:

public int compute(int a, Function<Integer, Integer> function1, Function<Integer, Integer> function2) {
    return function1.compose(function2).apply(a);
}

調(diào)用這個方法:

test.compute(2, value -> value * 3, value -> value * value) 

大家可以猜一下上面的結(jié)果是多少?

我們來分析一下:

function1.compose(function2).apply(a);

compose方法內(nèi)部代碼是:

return (V v) -> apply(before.apply(v));

返回的是一個Function,輸入一個參數(shù),返回一個參數(shù)值,這個Function 在調(diào)用apply時首先執(zhí)行的是 before.apply(v) before在這里就是value -> value * value,也就是 2*2,將得到的結(jié)果4,作為參數(shù)傳遞給function1,在這里就是value -> value * 3 ,所以結(jié)果是:12

3.Function andThen

了解了compose方法,我們再來看andThen方法就好理解了,聽名字就是“接下來”,andThen方法也是接收一個function作為參數(shù),與compse不同的是,先執(zhí)行本身的apply方法,將執(zhí)行的結(jié)果作為參數(shù)給參數(shù)中的function。

public interface Function<T, R> {
    default <V> Function<T, V> andThen(Function<? super R, ? extends V> after) {
        Objects.requireNonNull(after);
        return (T t) -> after.apply(apply(t));
    }
}

下面我們來舉例看一下:

public int compute2(int a, Function<Integer, Integer> function1, Function<Integer, Integer> function2) {
    return function1.andThen(function2).apply(a);
}

調(diào)用這個方法:

test.compute2(2, value -> value * 3, value -> value * value) 

這次結(jié)果是多少呢?我想大家應(yīng)該很容易就知道了,首先執(zhí)行的是 value -> value * 3 結(jié)果是6,然后執(zhí)行的是 value * value 最終結(jié)果是36

BiFunction

了解了Function以后,有的小伙伴可能會問了,F(xiàn)unction只能接收一個參數(shù),如果我要傳遞兩個參數(shù)呢,這一點Java8也替我們考慮到了,就是我們截下來要講到的 BiFunction,首先還是直接上源碼:

@FunctionalInterface
public interface BiFunction<T, U, R> {
    R apply(T t, U u);
 
    default <V> BiFunction<T, U, V> andThen(Function<? super R, ? extends V> after) {
        Objects.requireNonNull(after);
        return (T t, U u) -> after.apply(apply(t, u));
    }
}

可以看到BiFunction的apply方法,接收兩個參數(shù),返回一個值,來看一個例子

public int compute3(int a, int b, BiFunction<Integer, Integer, Integer> biFunction) {
   return biFunction.apply(a, b);
}

我們定義了一個方法,可以用來計算兩個數(shù)的很多運算

test.compute3(2, 3, (v1, v2) -> v1 + v2) //5
test.compute3(2, 3, (v1, v2) -> v1 - v2) //-1
test.compute3(2, 3, (v1, v2) -> v1 * v2) //6

這個還是蠻簡單的,我們再來看一下,BiFunction中有一個andThen方法,參數(shù)是一個Function,方法主要是將BiFunction返回的結(jié)果作為Function的參數(shù),得出一個結(jié)果,舉例:

public int compute4(int a, int b, BiFunction<Integer, Integer, Integer> biFunction,Function<Integer, Integer> function) {
    return biFunction.andThen(function).apply(a, b);
}
test.compute4(2, 3, (v1, v2) -> v1 + v2, v1 -> v1 * v1)

首先執(zhí)行(v1, v2) -> v1 + v2,然后執(zhí)行 v1 -> v1 * v1。

有的同學(xué)可能會問為什么BiFunction沒有compose方法呢,大家仔細(xì)想一想,如果有compose方法的話,那就是先執(zhí)行Function的apply方法,但是執(zhí)行完畢后只返回一個參數(shù),而BiFunction需要兩個參數(shù),所以肯定是不行的。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容