Java8新特性之Lambda表达式

本文深入探讨Java中的Lambda表达式,介绍其语法、如何简化代码,以及与函数式接口的关系。同时,文章还讲解了方法引用、构造器引用和数组引用的概念及应用。

1-Lambda表达式

Lambda是一个匿名函数,我们可以把Lambda表达式理解为一段可以传递的代码(将代码像数据一样进行传递)。可以写出更简洁、更灵活的代码。

//原来的匿名内部类
    @Test
    public void test1(){
        Comparator<Integer> comparator = new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return Integer.compare(o1,o2);
            }
        };
        TreeSet<Integer> ts = new TreeSet<>(comparator);
    }

    //Lambda表达式
    @Test
    public void test2(){
        Comparator<Integer> comparator = (x,y)->Integer.compare(x,y);
        TreeSet<Integer> ts = new TreeSet<>(comparator);
    }

 Lambda表达式在Java语言中引入了"->"操作符,该操作符被称为Lambda操作符。它将Lambda分为两部分:

左侧:指定了Lambda表达式所需要的所有参数

右侧:指定了Lambda体,即Lambda表达式要执行的功能

Lambda表达式语法

语法一:无参,无返回值,Lambda体只需一条语句

Runnable run = ()->System.out.println("Hello Lambda!");

语法二:Lambda需要一个参数

Consumer<String> fun = (args)-> System.out.println(args);

语法三:Lambda需要一个参数是,参数的小括号可以省略

Consumer<String> fun = args-> System.out.println(args);

语法四:Lambda需要两个参数,并且有返回值

BinaryOperator<Long> bo = (x,y)->{
    System.out.println("实现函数接口方法");
    return x+y;
}

语法五:当Lambda只有一条语句时,return与大括号可以不写

BinaryOperator<Long> bo = (x,y)-> return x+y;

 语法六:数据类型可以省略,因为可以由编译器推断得出,称为“类型推断” ,这是因为javac根据程序的上下文,在后台推断出参数的类型。

BinaryOperator<Long> bo = (Long x,Long y)->{
    System.out.println("实现函数接口方法");
    return x+y;
}

 函数式接口

  1. 只包含一个抽象方法的接口,称为函数式接口
  2. 你可通过Lambda表达式来创建该接口的对象。
  3. 我们可以在任意函数式接口上使用@FunctionalInterface注解,这样做可以检查它是否是一个函数式接口,同时,javadoc也会包含一条声明,说明这个接口是一个函数式接口
@FunctionalInterface
public interface MyFun<T> {
    public T getValue(T num);
}
public String toUpperString(MyFun<String> mf,String str){
    return mf.getValue(str);
}
String newStr = toUpperString(str->str.toUpperCase(),"abcdef");

 Java内置四大核心函数式接口

 方法引用

若Lambda体中的内容有已经实现的方法,我们可以使用”方法引用“(可以理解为方法引用是Lambda表达式的另外一种表现形式)

主要的格式有三种:

  1. 对象::实例方法名
  2. 类::静态方法名
  3. 类::实例方法名

Lambda体中调用方法的参数列表和返回值类型,要与函数式接口中抽象方法的函数列表和返回类型保持一致

若Lambda参数列表中第一个参数是实例方法的调用者,而第二个参数是实例方法的参数时,可以使用ClassName::method

构造器引用

格式:

ClassName::new

数组引用

格式

Type[]::new

    //对象::实例方法
    @Test
    public void test1(){
        Consumer<String> con = (x)-> System.out.println(x);

        PrintStream ps = System.out;
        Consumer<String> consumer = ps::println;
    }

    @Test
    public void test2(){
        Employee employee = new Employee();
        Supplier<String> sup = ()->employee.getName();
        String str = sup.get();
        System.out.println(str);

        Supplier<Integer> sup1 = employee::getAge;
        Integer integer = sup1.get();
        System.out.println(integer);
    }


    //类::静态方法名
    public void test3(){
        Comparator<Integer> com = (x,y)->Integer.compare(x,y);

        Comparator<Integer> com2 = Integer::compare;
    }

    //类::实例方法
    @Test
    public void test4(){
        BiPredicate<String,String> bp = (x,y)->x.equals(y);
        BiPredicate<String,String> bp2 = String::equals;
    }

    //构造器引用
    @Test
    public void test5(){
        Supplier<Employee> supplier = ()->new Employee();
        supplier.get();

        Supplier<Employee> supplier2 = Employee::new;//无参构造器
        Employee emp = supplier2.get();
        System.out.println(emp);

    }

    @Test
    public void test6(){
        Function<Integer,Employee> fun = (x)->new Employee(x);
        Function<Integer,Employee> fun2 = Employee::new;
        Employee employee = fun2.apply(35);
        System.out.println(employee);
    }

    //数组引用:
    @Test
    public void test7(){
        Function<Integer,String[]> fun = (x)->new String[x];
        String[] apply = fun.apply(10);
        System.out.println(apply.length);

        Function<Integer,String[]> fun2 = String[]::new;
        String[] apply1 = fun2.apply(20);
        System.out.println(apply1.length);
    }

 

已经博主授权,源码转载自 https://pan.quark.cn/s/a4b39357ea24 常见问题解答 网页打开速度慢或者打不开网页? 受到多种因素的影响,对于非会员用户我们无法提供最优质的服务。 如果您希望得到最棒的体验,请至大会员页面("右上角菜单 → 大会员")根据说明操作。 请注意:受制于国际网络的诸多不确定性,我们无法对任何服务的可靠性做出任何保证。 如果出现了网络连接相关的问题,我们建议您先等待一段时间,之后再重试。 如果您在重试后发现问题仍然存在,请联系我们,并说明网络问题持续的时间。 图片下载后无法找到? 打开"右上角菜单 → 更多 → 修改下载路径",在弹出的对话框中可以看到当前图片的保存路径。 此外,由于网络因素,在保存图片之后,等待屏幕下方出现"已保存到..."后,才能在本地找到图片。 如何更改图片保存的目录? 请参见"右上角菜单 → 更多 → 修改下载路径"。 翻页不方便? 在点进某个图片后,通过在图片上向左或向右滑动,即可翻页查看下一个作品。 如何保存原图/导出动图? 长按图片/动图,在弹出的菜单中选择保存/导出即可。 输入账号密码后出现"进行人机身份验证"? 此为pixiv登陆时的验证码,请按照要求点击方框或图片。 在pxvr中注册pixiv账号后,收到验证邮件,无法访问邮件中的验证链接? 请复制邮件中的链接,打开pxvr中的"右上角菜单 → 输入地址"进行访问。 能否自动将页面内容翻译为汉语? 很抱歉,pxvr暂不提供语言翻译服务。 图片下载类型是否可以选择? 能否批量下载/批量管理下载? 已支持批量下载多图作品中的所有原图:找到一个多图作品,进入详情页面后,点击图片进入多图浏览模式,长按任意一张图片即可看到批量下载选项。 关于上述其他功能,我们...
考虑局部遮阴的光伏PSO-MPPT控制模型(Simulink仿真实现)内容概要:本文介绍了基于Simulink仿真实现的考虑局部遮阴的光伏PSO-MPPT控制模型,旨在通过粒子群优化(PSO)算法解决光伏发电系统在局部阴影条件下最大功率点跟踪(MPPT)的效率问题。文档不仅提供了该模型的技术实现方法,还列举了大量相关的MATLAB/Simulink仿真资源,涵盖电力系统、智能优化算法、机器学习、路径规划、信号处理等多个科研方向,适用于复现高水平期刊论文和开展创新性研究。文中强调科研需逻辑缜密、善于借力,并提倡结合实际仿真与理论分析以提升研究深度。 适合人群:具备一定电力电子、自动控制或新能源背景,熟悉MATLAB/Simulink环境,从事光伏系统优化、智能算法应用或相关领域研究的研发人员及硕博研究生。 使用场景及目标:①研究局部遮阴下光伏系统MPPT控制策略的性能提升;②利用PSO等智能优化算法解决非线性、多峰值优化问题;③复现SCI/EI级别论文中的MPPT控制模型;④开展光伏系统建模与仿真教学或项目开发。 阅读建议:建议读者结合文档提供的网盘资源,下载完整代码与模型文件,按照目录顺序逐步学习,重点理解PSO算法在MPPT中的应用机制,并通过修改参数、对比实验等方式深入掌握仿真细节,提升工程实践与科研创新能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值