java8增加了对lambda表达式的支持,还优化了很多类库的API。
函数接口注释
@FunctionalInterface注解可以明确的表明此接口是函数接口(lambda表达式的类型)。Lambda表达式要求函数接口中只有一个抽象函数,但是反过来,只有一个抽象函数的接口并不一定是要用作函数接口使用的(像java.lang.Closeable)。增加上此注解之后就很容易区分,并且此注解会让javac在编译时强制检查是否满足函数接口的限制。
默认方法
java8优化了很多集合类库的API,导致有使用第三方集合类库的java进程无法做到兼容。为解决这种不兼容性,java8中引入了默认方法,使用default关键字。
- 优点
实现简单,可以实现接口改动并且满足向前兼容 - 缺点
当两个接口中实现了同样签名的默认方法,并且一个实现类同时继承了此两个接口,则会导致编译出错 - 继承
类中重写的方法优先级高于接口中定义的默认方法;如果类中没有重写,则继承接口中的默认方法。
三条定律:1,类胜于接口;2,子类胜于父类;3,没有规则三,如果上面两条规则不适用,子类要么实现该方法,要么将方法声明成抽象方法。
接口的静态方法
当一个方法有充分的语义原因和某个概念相关,就应该将该方法和相关的类或者接口放在一起,而不是放到另一个工具类中。例如Stream中的of方法是生成Stream的方法。
Optional
Optional是为核心类库新设计的一个数据类型,用来替换null值。null一般用来表示值不存在但是总是会出现烦人的NullPointerException,Optional对象能更好的表达这个概念:首先,Optional鼓励程序员适时检查变量是否为空;其次,它将一个类的API中可能为空的值文档化,这比阅读实现代码要简单很多。
- 使用工厂方法of/empty或者ofNullable创建Optional对象
- 使用get方法获取Optional对象对应的值(这样看Optional类似一个容器),但使用前需要使用isPresent来检查是否有值。
- 可以使用更简单的方法获取值,orElse/orElseGet
方法引用
方法引用是java8为lambda表达式提供的一个简写语法,凡是使用Lambda表达式的地方都可以使用方法引用。
- 标准语法
Classname::methodName
//Lambda表达式形式(flatMap的参数)
System.out.println("min: " + Stream.of(asList(1, 2), asList(3, 4)).flatMap(s -> s.stream()).min(Comparator.comparing(n -> n)).get());
//方法引用形式(flatMap的参数)
System.out.println("min: " + Stream.of(asList(1, 2), asList(3, 4)).flatMap(List::stream).min(Comparator.comparing(n -> n)).get());
- 方法引用自动支持多个参数,前提是选对正确的函数接口
//Lambda表达式形式
(name, nationality) -> new Artist(name, nationality);
//方法引用形式
Artist::new
参考
《java 8函数式编程》