Java 中的默认函数式接口
来源:dev.to
时间:2024-09-21 15:34:05 342浏览 收藏
从现在开始,我们要努力学习啦!今天我给大家带来《Java 中的默认函数式接口》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!
刚刚学习完 java 中的默认函数接口,我想把它们全部分享出来!
函数式接口是只有一种抽象方法的接口。如果您要处理 lambda 表达式(函数式编程),它们是必需的。它们简化了代码并广泛用于流中。虽然您可以创建自己的函数式接口,但当 java 为我们提供了一些重要的接口(例如 consumer、predicate、function 和supplier)时,为什么还要担心呢?
1. 消费者:
consumer 是一个函数式接口,表示接受单个输入参数且不返回结果的操作。它通常用于对给定参数执行操作(例如打印或记录)而不修改它。
签名:void accept(t t)(其中 t 是通用类型)
2. 谓词:
predicate 是一个函数式接口,表示返回布尔值的单个参数函数。它通常用于过滤或评估条件(例如,检查数字是否为偶数)。
签名:布尔测试(t t)
3、功能:
function 是一种函数式接口,表示接受一个参数并产生结果的函数。它通常用于转换(例如,将一种类型转换为另一种类型或修改数据)。
签名:r apply(t t)
4. 供应商:
supplier 是一个函数式接口,它表示一个没有输入参数并返回结果的函数。它通常用于生成或提供值而不需要输入。
签名:t get()
我们可以通过定义接受这些接口作为参数的通用方法来有效地使用函数式接口,例如 consumer、predicate、function 和supplier。这使我们能够利用泛型的强大功能并确保我们的方法可以适用于各种类型。
这是完整代码的示例,演示了所有功能
import java.util.List; import java.util.Random; import java.util.function.*; public class Main { public static void main(String[] args) { // Consumer usingConsumer((a) -> System.out.printf("Hello %s", a), "saami"); System.out.println(); // Bi-Consumer usingBiConsumer((a, b) -> System.out.printf("Name: %s, Age: %d", a, b), "saami", 20); System.out.println(); // Predicate var result1 = usingPredicate((a) -> a % 2 == 0, 34); if (result1) { System.out.println("Even"); } else { System.out.println("Odd"); } // Bi-Predicate var result2 = usingBiPredicate((a, b) -> a > b, 12, 22); if (result2) { System.out.println("Greater"); } else { System.out.println("Lesser"); } // Function var result3 = usingFunction((a) -> a + ": this is a number", 5); System.out.println(result3); // Bi-Function var result4 = usingBiFunction((a, b) -> (a > b ? "Greater": "Lesser"), 5, 6); System.out.println(result4); // Unary-Operator var result5 = usingUnaryOperator((a) -> a+5, 10); System.out.println(result5); // Binary-Operator var result6 = usingBinaryOperator((a, b) -> a + b, 12, 32); System.out.println(result6); Random r = new Random(); // Function as Predicate var result7 = usingFunctionAsPredicate((a) -> a > 99, 999); System.out.println(result7); // Using Consumer for printing of the list. printData((a) -> { for (var ele : a) { System.out.println(ele); } } , List.of("S1", "S2", "S3", "S4", "S5")); // Using Supplier as a random number generator String[] arr = {"saami", "john", "raymond", "puff"}; System.out.println(getRandomOne(arr, () -> new Random().nextInt(arr.length))); // Using Custom Comparator System.out.println(usingCustomFunctionalInterface((a, b, c) -> a + b + c, "Saami", " Abbas", " Khan")); } public staticvoid usingConsumer(Consumer consumer, T a) { // Method that takes consumer interface will return void. // Can print something constituting 'a' consumer.accept(a); } public static void usingBiConsumer(BiConsumer biConsumer, T a, L b) { biConsumer.accept(a, b); } public static boolean usingPredicate(Predicate predicate, T a) { return predicate.test(a); } public static boolean usingBiPredicate(BiPredicate biPredicate, T a, L b) { return biPredicate.test(a, b); } public static R usingFunction(Function function, T a) { // T for the parameter and R for the return type here the return type could be as same as T or // could be different like if T is Integer the R could be String 8 + "" return function.apply(a); } public static R usingBiFunction(BiFunction biFunction, T a, U b) { return biFunction.apply(a, b); } public static T usingUnaryOperator(UnaryOperator unaryOperator, T a) { return unaryOperator.apply(a); } public static T usingBinaryOperator(BinaryOperator binaryOperator, T a, T b) { return binaryOperator.apply(a, b); } public static R usingFunctionAsPredicate(Function prediFunction, T a) { return prediFunction.apply(a); } public static void printData(Consumer consumer, T a) { /* * Prints the data, (List.of()) using a for loop inside of lambda function. */ consumer.accept(a); } public static String getRandomOne(String[] arr, Supplier supplier) { return arr[supplier.get()]; } @FunctionalInterface interface Concat { T concat(T a, T b, T c); } public static T usingCustomFunctionalInterface(Concat concat, T a, T b, T c) { return concat.concat(a, b, c); } }
最终判决
java 中的函数式接口是简化代码和提高可读性的强大工具。无论您是处理集合、执行转换还是处理数据流,这些接口都可以让您更轻松地定义简洁的操作。
通过理解和应用 consumer、predicate、function、supplier 和自定义接口等函数式接口,您可以充分利用 java 的函数式编程功能。
今天关于《Java 中的默认函数式接口》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
213 收藏
-
348 收藏
-
381 收藏
-
405 收藏
-
169 收藏
-
328 收藏
-
270 收藏
-
351 收藏
-
459 收藏
-
133 收藏
-
267 收藏
-
278 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习