两千字详解Java 8 中必知的4个函数式接口

前言JAVA 8 中提供了许多函数式接口,包括Function、Consumer、Supplier、Predicate 等等 。这 4 个接口就是本篇将要分享的内容,它们都位于 java.util.function 包下 。

两千字详解Java 8 中必知的4个函数式接口

文章插图
 
为什么需要知道这几个函数式接口?因为这 4 个函数式接口是 Java 8 中新增的重要接口,同时 Java 8 的 Stream 新特性,也有用到这些接口,所以学习它们可以帮助我们更好地理解 Stream 流 。
也正因为这是函数式接口,所以就可以使用 Lambda 表达式来写接口的实现逻辑 。而且学习的过程中可以更好地理解函数式编程的思想 。
Function 接口说明Function 这个单词的意思就有「函数」的意思,就数学中的 y = f(x),接收一个 x 参数,通过函数 f 运算后,返回一个结果 y 。
Function 接口包含四个方法:
  • Apply(T t):这是 Function 接口的主要方法,它接收一个参数并返回一个结果 。同时它也是唯一的抽象的方法,剩下的都是有默认实现的(Java 8 中接口的抽象方法支持默认实现) 。
  • andThen(Function after):作用是将两个 Function 组合 。首先执行当前函数,再执行 andThen 函数,并将当前函数的结果作为参数传递给 andThen 函数 。
  • compose(Function before):同理,将两个 Function 组合,将先执行 compose 函数,再执行当前函数,并将 compose 函数的结果作为参数传递给当前函数 。
  • identity(): 返回一个执行恒等转换的函数,即返回输入参数本身 。
Function 接口通常用于将一个类型的值转换为另一个类型的值 。
apply 方法【两千字详解Java 8 中必知的4个函数式接口】// Function 接口的泛型,第一个参数是入参类型,第二个参数是出参类型// Function 接口只有一个抽象方法,就是 apply(),下面利用 Lambda 表达式实现这个抽象方法并创建 Function 对象Function<Integer, String> function = num -> "GTA" + num;// 将5这个参数传递给function,得到返回结果String result = function.apply(5);System.out.println(result); // 打印:GTA5复制代码andThen 和 compose 方法// 定义两个 Function 对象进行相关转换操作Function<String, String> upperCase = s -> s.toUpperCase();Function<String, String> addPostfix = s -> s + "5";// 链式调用,将 gta 这个字符串参数先传递 upperCase 这个函数进行操作,然后将得到的结果传递给 addPostfix 函数进行操作,得到返回结果String str = upperCase.andThen(addPostfix).apply("gta");System.out.println(str); // 打印:GTA5复制代码identify 方法identity 方法返回一个执行恒等转换的函数,该函数将输入参数原样返回 。例如:
Function<String, String> identity = Function.identity();String result = identity.apply("hello"); // 打印:hello复制代码Consumer 接口说明Consumer 这个单词的意思就有「消费者」的意思,就把入参消费了,并不会返回结果给你 。
Consumer 接口包含两个方法:
  • accept(T t):该方法接受一个参数并执行一些操作 。
  • andThen(Consumer after):同理,将两个 Consumer 组合,先后进行消费 。
accept 方法Consumer 接口通常用于消费一个参数然后执行一些操作 。例如:
// Consumer 接口,泛型参数是入参类型,接受一个参数,并不返回结果,相当于消费了这个参数Consumer<String> consumer = s -> System.out.println(s);consumer.accept("我输入什么就打印什么"); // 打印:我输入什么就打印什么复制代码andThen 方法组合两个 Consumer:
Consumer<String> first = s -> System.out.println(s + 5);Consumer<String> second = s -> System.out.println(s + 6);// 先执行 first 这个 Consumer,接着执行 second 这个 ConsumerConsumer<String> combination = first.andThen(second);combination.accept("GTA"); // 打印:GTA5 GTA6复制代码Supplier 接口Supplier 接口只定义了一个 get() 方法,该方法不接受任何参数并返回一个结果 。
Supplier 这个单词的意思就有「供应者」的意思,给我的感觉就是生产者,不用参数,直接生产一个东西给你 。
Supplier 接口通常用于生成一个值 。例如:
// Supplier 接口,泛型参数是出参类型,不接受参数,但是会提供结果,相当于生产了某个东西Supplier<String> supplier = () -> "提供一个我随便打的字符串给调用方";String text = supplier.get();System.out.println(text); // 打印:提供一个我随便打的字符串给调用方复制代码


推荐阅读