让星星⭐月亮告诉你,jdk1.8 Java函数式编程示例:Lambda函数/方法引用/4种内建函数式接口(功能性-/消费型/供给型/断言型)

简介: 本示例展示了Java中函数式接口的使用,包括自定义和内置的函数式接口。通过方法引用,实现对字符串操作如转换大写、数值转换等,并演示了Function、Consumer、Supplier及Predicate四种主要内置函数式接口的应用。

package unittest;

import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.Predicate;
import java.util.function.Supplier;

@FunctionalInterface
interface IFuction1

{
public abstract P uppCase();
}
@FunctionalInterface
interface IFuction2

{
public abstract P uppCase(P p);
}
@FunctionalInterface
interface IFuction3{
public abstract R trans(P p);
}
public class TestLocal{
public static void main(String[] args) {
//利用方法引用的概念可以位一个方法定义多个名字,但是要求必须是函数式接口.

    IFuction1<String> ifunction1  = "avc" :: toUpperCase;//    public String toUpperCase() {
    String str1 = ifunction1.uppCase();//实例对象::普通方法(不带参数)
    System.out.println(str1);

    IFuction2<String> ifunction2  = String :: toUpperCase; //    public String toUpperCase() {
    String str2 = ifunction2.uppCase("avc");//类名称::普通方法(带参数)
    System.out.println(str2);

    IFuction3<Integer,String> ifunction3  = String :: valueOf;//类名称::static方法(带参数) //    public static String valueOf(int i) {
    String str3 = ifunction3.trans(123456);
    System.out.println(str3.length());
    //内建函数式接口
    //1.功能型内建函数式接口:有参数 有返回值
    Function<String,Boolean> fun = "abc123"::startsWith;
    System.out.println("1功能型内建函数式接口:" + fun.apply("abc"));

    //2.消费型内建函数式接口:有参数 无返回值
    Consumer<String> con = System.out::println;
    con.accept("2消费型内建函数式接口:avc");
    //3.供给型内建函数式接口:无参数 有返回值
    Supplier<String> supplier = "abc"::toUpperCase;
    System.out.println("3供给型内建函数式接口:" + supplier.get());
    //4.断言型内建函数式接口:无参数 有返回值
    Predicate<String> predicate = String::isEmpty;
    System.out.println("4断言型内建函数式接口:" + predicate.test("a"));

    Predicate<String> fun_predicate = "abc123"::startsWith;
    System.out.println("5功能_断言型内建函数式接口:" + fun_predicate.test("abc"));
}
AI 代码解读

}

相关文章
JDK 10中的局部变量类型推断:Java编程的简化与革新
JDK 10引入的局部变量类型推断通过`var`关键字简化了代码编写,提高了可读性。编译器根据初始化表达式自动推断变量类型,减少了冗长的类型声明。虽然带来了诸多优点,但也有一些限制,如只能用于局部变量声明,并需立即初始化。这一特性使Java更接近动态类型语言,增强了灵活性和易用性。
144 53
|
5月前
|
Java中内置的函数式接口
Java中内置的函数式接口
60 2
|
7月前
|
java基础(11)函数重载以及函数递归求和
Java支持函数重载,即在同一个类中可以声明多个同名方法,只要它们的参数类型和个数不同。函数重载与修饰符、返回值无关,但与参数的类型、个数、顺序有关。此外,文中还展示了如何使用递归方法`sum`来计算两个数之间的和,递归的终止条件是当第一个参数大于第二个参数时。
50 1
java基础(11)函数重载以及函数递归求和
|
6月前
|
【编程进阶知识】静态代理、JDK动态代理及Cglib动态代理各自存在的缺点及代码示例
本文介绍了三种Java代理模式:静态代理、JDK动态代理和Cglib动态代理。静态代理针对特定接口或对象,需手动编码实现;JDK动态代理通过反射机制实现,适用于所有接口;Cglib动态代理则基于字节码技术,无需接口支持,但需引入外部库。每种方法各有优缺点,选择时应根据具体需求考虑。
58 1
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
63 3
Linux下JDK环境的配置及 bash: /usr/local/java/bin/java: cannot execute binary file: exec format error问题的解决
如果遇到"exec format error"问题,文章建议先检查Linux操作系统是32位还是64位,并确保安装了与系统匹配的JDK版本。如果系统是64位的,但出现了错误,可能是因为下载了错误的JDK版本。文章提供了一个链接,指向Oracle官网上的JDK 17 Linux版本下载页面,并附有截图说明。
Linux下JDK环境的配置及 bash: /usr/local/java/bin/java: cannot execute binary file: exec format error问题的解决
在Rocky Linux 9上安装JDK并配置环境变量!
本教程介绍在Rocky Linux 9上安装JDK并配置环境变量的完整步骤。首先更新系统,清理旧版本JDK相关包及残留文件,确保环境干净。接着搜索并安装所需版本的JDK(如OpenJDK 17),验证安装是否成功。然后查找JDK安装路径,配置全局环境变量`JAVA_HOME`和`PATH`,最后验证环境变量设置。按照此流程操作,可顺利完成Java开发环境搭建,支持多版本切换(如JDK 8/11/17)。生产环境请谨慎操作,避免影响现有服务。
76 21
|
7月前
|
安装JDK18没有JRE环境的解决办法
安装JDK18没有JRE环境的解决办法
612 61
课时4:JDK的安装与配置
课时4:JDK的安装与配置 摘要: 1. JDK安装:从Oracle官网下载适合操作系统的JDK版本,确保关闭防火墙,选择正确的位数(如64位),并进行一键式安装。 2. JDK配置:将JDK的bin目录路径(如D:\Java\jdk1.8.0_74\bin)添加到系统环境变量PATH中,确保Java开发命令(如javac、java)可用。配置完成后,重启命令行工具验证安装是否成功。 通过以上步骤,确保Java开发环境的正确搭建。
112 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等