Vavr

Vavr

Java 8引入了函数式编程范式,思路是:将函数作为其他函数的参数传递,其实在Java 8之前,Java也支持类似的功能,但是需要使用接口实现多态,或者使用匿名类实现。不管是接口还是匿名类,都有很多模板代码,因此Java 8引入了Lambda表达式,正式支持函数式编程。

比方说,我们要实现一个比较器来比较两个对象的大小,在Java 8之前,只能使用下面的代码:

Compartor<Apple> byWeight = new Comparator<Apple>() {
  public int compare(Apple a1, Apple a2) {
    return a1.getWeight().compareTo(a2.getWeight());
  }
}

上面的代码使用Lambda表达式可以写成下面这样(IDEA会提示你做代码的简化)

Comparator<Apple> byWeight = (Apple a1, Apple a2) -> a1.getWeight().compareTo(a2.getWeight());

受限于Java标准库的通用性要求和二进制文件大小,Java标准库对函数式编程的API支持相对比较有限。函数的声明只提供了FunctionBiFunction两种,流上所支持的操作的数量也较少。基于这些原因,你也许需要vavr来帮助你更好得使用Java 8进行函数式开发。如下图所示,vavr提供了不可变的集合框架;更好的函数式编程特性;元组。vavr是在尝试让Java拥有跟Scala类似的语法。

扩展支持

<dependency>
  <groupId>io.vavr</groupId>
  <artifactId>vavr-jackson</artifactId>
  <version>0.10.3</version>
</dependency>

首先注册VavrModule的实例:

ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(new VavrModule());

然后就可以进行序列化操作了:

String json = mapper.writeValueAsString(List.of(1));
// = [1]
List<Integer> restored = mapper.readValue(json, new TypeReference<List<Integer>>() {});
// = List(1)