163. Java Lambda 表达式 - Function 的链式组合

163. Java Lambda 表达式 - Function 的链式组合

在函数式编程中,我们常常希望把多个功能组合起来形成一个新的功能。Java 的 Function<T, R> 接口为此提供了两个非常实用的默认方法:

🧩 andThen() ------ 先执行当前函数,再执行参数函数

java 复制代码
Function<T, R> f1;
Function<R, V> f2;

Function<T, V> result = f1.andThen(f2);

🧩 compose() ------ 先执行参数函数,再执行当前函数

java 复制代码
Function<T, R> f1;
Function<U, T> f2;

Function<U, R> result = f1.compose(f2);

🎯 理解两者的执行顺序

方法名 执行顺序 相当于代码
andThen() f1f2 f2(f1(x))
compose() f2f1 f1(f2(x))

它们实现的是相同的功能组合 ,只是调用方式不同,谁写在前面,谁先执行


📦 实例演示:名字处理链

假设我们有一组名字,需要做如下处理:

  1. 去掉前后空格;
  2. 全部转为大写;
  3. 添加前缀 "Hello, "。

我们可以把这几个步骤封装成函数:

java 复制代码
Function<String, String> trim = String::trim;
Function<String, String> toUpper = String::toUpperCase;
Function<String, String> addPrefix = name -> "Hello, " + name;

✅ 方式一:使用 andThen() 链接函数

java 复制代码
Function<String, String> greet = trim.andThen(toUpper).andThen(addPrefix);
System.out.println(greet.apply("  alice  ")); // 输出:Hello, ALICE

执行顺序是:

  1. trim(" alice ")"alice"
  2. toUpper("alice")"ALICE"
  3. addPrefix("ALICE")"Hello, ALICE"

✅ 方式二:使用 compose() 组合函数(写法反过来)

java 复制代码
Function<String, String> greet = addPrefix.compose(toUpper).compose(trim);
System.out.println(greet.apply("  alice  ")); // 输出:Hello, ALICE

⚠️ 虽然顺序看起来反了,其实执行顺序和 andThen() 完全一样!


🧠 小贴士:如何选用?

情况 推荐方法
自然顺序思维(从左到右) andThen()
倒推逻辑(从右到左) compose()

🛑 类型兼容性注意

不论你是使用 andThen() 还是 compose(),都要确保类型兼容:

  • f1.andThen(f2)f1 的返回类型必须是 f2 的输入类型。
  • f1.compose(f2)f2 的返回类型必须是 f1 的输入类型。
java 复制代码
Function<Integer, Double> half = i -> i / 2.0;
Function<Double, String> asString = d -> "Result: " + d;

// 合法组合
Function<Integer, String> composed = half.andThen(asString);

🧪 练习题(课堂互动)

编写一个函数组合链,接收一个字符串,输出结果如下格式:

"Length: <长度>"

提示步骤:

  1. 去掉空格;
  2. 获取长度;
  3. 拼接前缀字符串。
相关推荐
JayceM24 分钟前
Vue中v-show与v-if的区别
前端·javascript·vue.js
HWL567928 分钟前
“preinstall“: “npx only-allow pnpm“
运维·服务器·前端·javascript·vue.js
小兔兔吃萝卜1 小时前
Spring 创建 Bean 的 8 种主要方式
java·后端·spring
德育处主任1 小时前
p5.js 掌握圆锥体 cone
前端·数据可视化·canvas
mazhenxiao1 小时前
qiankunjs 微前端框架笔记
前端
无羡仙1 小时前
事件流与事件委托:用冒泡机制优化前端性能
前端·javascript
秃头小傻蛋1 小时前
Vue 项目中条件加载组件导致 CSS 样式丢失问题解决方案
前端·vue.js
CodeTransfer1 小时前
今天给大家搬运的是利用发布-订阅模式对代码进行解耦
前端·javascript
阿邱吖1 小时前
form.item接管受控组件
前端
韩劳模1 小时前
基于vue-pdf实现PDF多页预览
前端