例子 1:
// 定義function Function<String, String> fun = parm -> { // 這里是定function中的邏輯 return String.valueOf(parm + "xing"); }; Function<String, String> fun1 = parm -> { // 這里是定function中的邏輯 return String.valueOf(parm + "sheng"); };
/* * @param a 第一個執行 * @param fun 第三個 * @param fun1 第二個 * @return */ public static String test3(String a, Function<String, String> fun,Function<String, String> fun1) { return fun.compose(fun1).apply(a); } // compose 源碼 default <V> Function<V, R> compose(Function<? super V, ? extends T> before) { Objects.requireNonNull(before); return (V v) -> apply(before.apply(v)); }
System.out.println(test3("zhang",fun,fun1)); // 輸出結果 zhangshengxing
// 例子2 list 轉map
// 初始化 測試數據
List<User>userList=new ArrayList<>(); userList.add(User.builder().age(10).name("zhang").build()); userList.add(User.builder().age(11).name("wang").build()); userList.add(User.builder().age(12).name("li").build()); userList.add(User.builder().age(13).name("zhao").build()); userList.add(User.builder().age(14).name("sun").build());
/** * 注:Flux 是 reactor 框架中的類,表示0~1個異步序列。Flux.fromIterable(a) 從a中獲取一個 Iterable遍歷器 從a中獲取一個 Iterable遍歷器,並使用collectMap(fun,fun1) 函數式方法,block 是堵塞 直到遍歷完成 Map<V,R> : V 是map的key, R map的值 例子2 是將list 轉為 map<name,age> 形式.
調用 test7(userList,User::getName,User::getAge) 此時,User::getName 是 fun的執行邏輯,User::getAge 是 fun1 的執行邏輯。這兩個方法引用
就是從遍歷的User中取出name和age 。 Fun<K,V> V 為出參,也就是map 的 key Fun1<K,R> R為出參,也就是map 的 value Fun,fun1 必須要和 map<V,R> 對應
* @param a 數據源 * @param fun key 邏輯 * @param fun1 value 邏輯 * @param <K> 數據源類型 * @param <V> key 類型 * @param <R> value 類型 * @return */ public static <V,R,K> Map<V,R> test7(List<K> a, Function<K,V> fun, Function<K,R> fun1) { return Flux.fromIterable(a).collectMap(fun,fun1).block(); }
Map<String,Integer>map=test7(userList,User::getName,User::getAge) // 輸出結果 {"zhang":10,"wang":11,"zhao":13,"li":12,"sun":14}
如果有錯誤 請大家留言指出