JDK8之Function接口

本文深入探讨了Java中Function接口的基本概念与使用方法,包括如何利用Function接口支持Lambda表达式,实现方法的封装与组合。文章通过实例展示了Function接口中的主要方法如apply(), andThen(), compose() 和 identity() 的具体应用场景。

新特性中有个Function接口用在支持lamdba表达式。

个人理解这个接口就是把一些输入参数封装在1个 or n个方法内,并且输出的结果类型可以和参数一致 or 不一致。

同时可以利用这个接口不断把方法迭代,用来完成方法的组合。

如果大家对于这个类的用法还有其他的想法,欢迎留言。




1.  R apply(T t) ->  将function对象应用到输入的参数上,并且输出结果


2. default <V> Function<T,V> andThen(Function<? super R, ? extends V> after) ->   先执行Function<T, R>对象的apply(),再执行after的apply(),返回一个新的Function

源码:


从源码上可以看出,先执行 Function<T, R> apply(t) = R, 然后再执行Function<R, V> apply(R) = V。 忽略过程,传入的参数为T,输出的结果为V.

我的理解为:假设n个andThen()迭代,那么就是不断用输出结果继续作为输入进行操作,最后一个出口的结果作为最终结果。


2. default <V> Function<V,R>compose(Function<? super V,? extends T> before)->   先执行before的apply(),再执行Function<T,R>的apply(),返回一个新的Function

源码:


从源码上可以看出,先执行 Function<V, T> apply(v) = T, 然后再执行Function<T, R> apply(T) = R。 忽略过程,初始传入的参数为T,输出的结果为R.

我的理解为:假设n个compose()迭代,那么就是为了得到R,前面的apply()不断输出,直至得到T。


4. static <T> Function<T,T>identity() -> 返回一个输入和输出都为T的Function对象。

源码:



例子:

        Function<String, Integer> f1 = (t) -> Integer.valueOf(t) * 10;
        System.out.println(f1.apply("3"));
        System.out.println(Function.identity().apply("3"));
        System.out.println(f1.andThen((r) -> String.valueOf(r) + ".....").apply("4"));
        System.out.println(f1.compose((String r) -> r.substring(1)).apply("a5"));
输出为:

30
3
40.....
50


### JDK 8 函数式接口的使用方法及示例 JDK 8 引入了函数式接口的概念,这种接口有且仅有一个抽象方法[^5]。通过使用 `@FunctionalInterface` 注解,可以明确标识某个接口是函数式接口[^2]。函数式接口的主要用途在于支持 Lambda 表达式的使用[^4]。 #### 示例代码:定义与使用函数式接口 以下是一个简单的函数式接口定义及其 Lambda 表达式的使用示例: ```java @FunctionalInterface public interface MyFunctionalInterface { void myMethod(String message); } public class FunctionalInterfaceExample { public static void main(String[] args) { // 使用 Lambda 表达式实现函数式接口 MyFunctionalInterface functionalInterface = (message) -> System.out.println("Message: " + message); // 调用接口中的方法 functionalInterface.myMethod("Hello, World!"); } } ``` 在上述代码中,`MyFunctionalInterface` 是一个函数式接口,它只有一个抽象方法 `myMethod`。通过 Lambda 表达式 `(message) -> System.out.println("Message: " + message)` 实现了该接口,并调用了其方法。 #### 内置常用函数式接口 JDK 8 提供了许多内置的函数式接口,例如 `Predicate<T>`、`Function<T, R>`、`Consumer<T>` 和 `Supplier<T>` 等。这些接口可以直接用于 Lambda 表达式或方法引用。 - **Predicate<T>**:用于判断条件的布尔值。 - **Function<T, R>**:用于将一种类型的值转换为另一种类型的值。 - **Consumer<T>**:用于对输入值执行某些操作。 - **Supplier<T>**:用于返回某种类型的值。 #### 示例代码:使用内置函数式接口 以下代码展示了如何使用内置的函数式接口: ```java import java.util.function.*; public class BuiltInFunctionalInterfaces { public static void main(String[] args) { // Predicate 示例 Predicate<String> isEmpty = str -> str.isEmpty(); System.out.println(isEmpty.test("")); // 输出 true // Function 示例 Function<String, Integer> stringLength = str -> str.length(); System.out.println(stringLength.apply("Hello")); // 输出 5 // Consumer 示例 Consumer<String> printMessage = message -> System.out.println(message); printMessage.accept("This is a test."); // 输出 This is a test. // Supplier 示例 Supplier<Double> randomValue = Math::random; System.out.println(randomValue.get()); // 输出随机数 } } ``` #### 默认方法与静态方法 除了抽象方法外,函数式接口还可以包含默认方法和静态方法[^3]。默认方法允许接口提供具体实现,而不需要子类强制实现。静态方法可以通过接口名直接调用。 #### 示例代码:默认方法与静态方法 ```java @FunctionalInterface public interface MyFunctionalInterfaceWithMethods { void myMethod(); // 默认方法 default void defaultMethod() { System.out.println("This is a default method."); } // 静态方法 static void staticMethod() { System.out.println("This is a static method."); } } public class DefaultAndStaticMethods { public static void main(String[] args) { MyFunctionalInterfaceWithMethods functionalInterface = () -> System.out.println("Hello, World!"); // 调用默认方法 functionalInterface.defaultMethod(); // 输出 This is a default method. // 调用静态方法 MyFunctionalInterfaceWithMethods.staticMethod(); // 输出 This is a static method. // 调用接口方法 functionalInterface.myMethod(); // 输出 Hello, World! } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值