共计 1046 个字符,预计需要花费 3 分钟才能阅读完成。
Lambda 表达式与函数式编程
java 新人, 学习记录笔记, 如有不对的中央, 欢送大佬指教
1. 函数式编程
Java 语言设计者们投入了大量精力来思考如何使现有的函数敌对地反对 Lambda。最终采取的办法是:减少函数式接口的概念。
“ 函数式接口 ” 指仅仅只蕴含一个形象办法, 然而能够有多个非形象办法 (也就是默认办法) 的接口。
像这样的接口,能够被隐式转换为 lambda 表达式。
java.lang.Runnable 与 java.util.concurrent.Callable 是函数式接口最典型的两个例子。
Java 8 减少了一种非凡的注解 @FunctionalInterface , 然而这个注解通常不是必须的(某些状况倡议应用),只有接口只蕴含一个形象办法,虚构机会主动判断该接口为函数式接口。个别倡议在接口上应用@FunctionalInterface 注解进行申明,这样的话,编译器如果发现你标注了这个注解的接口有多于一个形象办法的时候会报错的
1.1 示例
@FunctionalInterface
public interface Converter<F, T> {T convert(F from);
}
// TODO 将数字字符串转换为整数类型
Converter<String, Integer> converter = (from) -> Integer.valueOf(from);
Integer converted = converter.convert("123");
System.out.println(converted.getClass()); //class java.lang.Integer
2. Lambda 表达式
2.1 示例(通过应用 mybatis-plus 比拟)
QueryWrapper<CallRecord> wrapper = new QueryWrapper<>();
// 第一种原始写法
wrapper.nested(new Consumer<QueryWrapper<CallRecord>>() {
@Override
public void accept(QueryWrapper<CallRecord> qw) {qw.eq("name","123");
}
});
// 第二种最简略 lambda 写法
wrapper.nested(wt->wt.eq("name","123"));
// 第三种省略局部 lambda 写法
wrapper.nested((QueryWrapper<CallRecord> wt)->{wt.eq("name", "123");
});
正文完