一文带你掌握Java8中Lambda表达式 函数式接口及方法构造器数组的引用

 更新时间:2021年10月08日 11:53:07   作者:叶绿体不忘呼吸  
Java 8 (又称为 jdk 1.8) 是 Java 语言开发的一个主要版本。 Oracle 公司于 2014 年 3 月 18 日发布 Java 8 ,它支持函数式编程,新的 JavaScript 引擎,新的日期 API,新的Stream API 等

函数式接口概述

只包含一个抽象方法的接口,称为函数式接口。

可以通过 Lambda 表达式来创建该接口的对象。

可以在一个接口上使用 @FunctionalInterface 注解,这样做可以检查它是否是一个函数式接口。同时 javadoc 也会包含一条声明,说明这个接口是一个函数式接口。

在java.util.function包下定义了Java 8 的丰富的函数式接口。

在函数式编程语言当中,函数被当做一等公民对待。在将函数作为一等公民的编程语言中,Lambda表达式的类型是函数。但是在Java8中,有所不同。在Java8中,Lambda表达式是对象,而不是函数,它们必须依附于一类特别的对象类型——函数式接口。

简单的说,在Java8中,Lambda表达式就是一个函数式接口的实例。这就是Lambda表达式和函数式接口的关系。也就是说,只要一个对象是函数式接口的实例,那么该对象就可以用Lambda表达式来表示。所以用匿名实现类表示的现在都可以用Lambda表达式来写。

函数式接口示例

1、Runnable接口

在这里插入图片描述

2、自定义函数式接口

@FunctionalInterface
public interface MyFunctional01{
    public String getValue();
}

//使用泛型
@FunctionalInterface
public interface MyFunctional02<T>{
    public T getValue(T t);
}

3、作为参数传递 Lambda 表达式

public class LambdaTest {
    public static void main(String[] args) {
        String newStr = toUpperString(str -> str.toUpperCase(),"abcDEf");
        System.out.println(newStr);
    }
    public static String toUpperString(MyFunc<String> my,String str){
        return my.getValue(str);
    }
}

@FunctionalInterface
interface MyFunc<T>{
    public T getValue(T t);
}

内置函数式接口

在这里插入图片描述

import java.util.function.Consumer;

/**
 * @Author: Yeman
 * @Date: 2021-10-03-22:50
 * @Description:
 */
public class LambdaTest {
    public static void main(String[] args) {
        Consumer<Integer> consumer = i -> System.out.println(i);
        consumer.accept(9);
    }
}

在这里插入图片描述

Lambda简述

Lambda 是一个匿名函数,我们可以把 Lambda 表达式理解为是一段可以传递的代码(将代码像数据一样进行传递)。使用它可以写出更简洁、更灵活的代码。作为一种更紧凑的代码风格,使Java的语言表达能力得到了提升。

其本质是作为函数式接口(只有一个抽象方法)的实例。

Lambda 表达式:在Java 8 语言中引入的一种新的语法元素和操作符。这个操作符为 “->” , 该操作符被称为 Lambda 操作符或箭头操作符。它将 Lambda 分为两个部分:
①左侧:指定了 Lambda 表达式需要的参数列表。
②右侧:指定了 Lambda 体,是抽象方法的方法体。

Lambda语法

1、无参,无返回值

public class LambdaTest {
    public static void main(String[] args) {
        //未使用Lambda表达式
        Runnable runnable1 = new Runnable() {
            @Override
            public void run() {
                System.out.println("这是第一个语法!");
            }
        };
        runnable1.run();
        System.out.println("======================");
        //使用Lambda表达式
        Runnable runnable2 = () -> {
            System.out.println("这是用了Lambda表达式的一个语法!");
        };
        runnable2.run();
    }
}

2、一个参数,无返回值

在这里插入图片描述


3、数据类型可以省略,因为可由编译器推断得出,称为“类型推断”

在这里插入图片描述


4、Lambda 若只需要一个参数时,参数的小括号可以省略

在这里插入图片描述


5、Lambda 需要两个或以上的参数,多条执行语句,并且可以有返回值

在这里插入图片描述


6、当 Lambda 体只有一条语句时,return 与大括号若有,都可以省略

在这里插入图片描述

方法引用

当要传递给Lambda体的操作,已经有实现的方法了,可以使用方法引用。

方法引用可以看做是Lambda表达式深层次的表达。换句话说,方法引用就是Lambda表达式,也就是函数式接口的一个实例,通过方法的名字来指向一个方法,可以认为是Lambda表达式的一个语法糖。

要求:实现接口的抽象方法的参数列表和返回值类型,必须与方法引用的方法的参数列表和返回值类型保持一致。

格式:使用操作符 “::” 将类(或对象)与方法名分隔开。

如下三种主要使用情况:
对象::非静态方法名
类::静态方法名
类::非静态方法名

示例:

import java.util.Comparator;
import java.util.function.Consumer;

/**
 * @Author: Yeman
 * @Date: 2021-10-03-22:50
 * @Description:
 */
public class LambdaTest {
    public static void main(String[] args) {

        Consumer<Integer> consumer = i -> System.out.println(i);
        consumer.accept(9);

        Consumer<String> stringConsumer = System.out :: println;
        stringConsumer.accept("Hello");

        Comparator<Integer> comparable = (x, y) -> Integer.compare(x,y);
        System.out.println(comparable.compare(2,9));

        Comparator<Integer> integerComparator = Integer :: compare;
        System.out.println(integerComparator.compare(9,2));
    }
}

构造器引用

格式:ClassName::new

与函数式接口相结合,自动与函数式接口中方法兼容。可以把构造器引用赋值给定义的方法,要求构造器参数列表要与接口中抽象方法的参数列表一致,且方法的返回值即为构造器对应类的对象。

在这里插入图片描述

数组引用

可以将数组看作一个类,则数组引用就类似于构造器引用。

格式:type[] :: new

import java.util.function.Function;

/**
 * @Author: Yeman
 * @Date: 2021-10-03-22:50
 * @Description:
 */
public class LambdaTest {
    public static void main(String[] args) {
        Function<Integer,String[]> function = length -> new String[length];
        String[] apply = function.apply(3);
        System.out.println(apply[2]);

        System.out.println("================");

        Function<Integer,String[]> function1 = String[] :: new;
        System.out.println(function1.apply(5));
    }
}

到此这篇关于一文带你掌握Java8中Lambda表达式 函数式接口及方法构造器数组的引用的文章就介绍到这了,更多相关Java Lambda表达式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot配置系统全局异常映射处理

    SpringBoot配置系统全局异常映射处理

    在项目开发中,肯定少不了异常的出现,作为后台开发人员,我们总是在不停的写各种接口提供给前端调用,然而不可避免的,当后台出现BUG时,前端总是丑陋的讲错误信息直接暴露给用户,这样的用户体验想必是相当差的,本文主要讲解异常映射的配置
    2021-06-06
  • Java实现在PPT中创建SmartArt图形的示例代码

    Java实现在PPT中创建SmartArt图形的示例代码

    SmartArt其实就是一个文字的可视化工具,用户可在PowerPoint,Word,Excel中使用该特性创建各种图形图表。本文就将为您介绍如何通过Java应用程序在PPT中创建SmartArt图形,需要的可以参考一下
    2023-04-04
  • Java利用反射对list对象做过滤

    Java利用反射对list对象做过滤

    这篇文章主要介绍了Java利用反射对list对象做过滤,但是使用反射对效率有影响,但在一些特殊情况也有一定的参考价值,需要的小伙伴可以参考一下
    2022-03-03
  • 解决mybatis映射结果集失效的问题

    解决mybatis映射结果集失效的问题

    这篇文章主要介绍了解决mybatis映射结果集失效的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • 详解SpringCloud微服务之Rest

    详解SpringCloud微服务之Rest

    今天带大家学习SpringCloud微服务之Rest的有关知识,文中有非常详细的介绍及代码示例,对正在学习java的小伙伴们有很好的帮助,需要的朋友可以参考下
    2021-05-05
  • Springboot设置默认访问路径方法实现

    Springboot设置默认访问路径方法实现

    这篇文章主要介绍了Springboot设置默认访问路径方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Intellij 下 mybatis 插件 MyBatisCodeHelperPro破解步骤详解

    Intellij 下 mybatis 插件 MyBatisCodeHelperPro破解步骤详解

    这篇文章主要介绍了Intellij 下 mybatis 插件 MyBatisCodeHelperPro破解步骤,本文分步骤给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • SpringBoot项目中使用AOP的方法

    SpringBoot项目中使用AOP的方法

    本篇文章主要介绍了SpringBoot项目中使用AOP的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-02-02
  • 如何修改覆盖spring boot默认日志策略logback详解

    如何修改覆盖spring boot默认日志策略logback详解

    这篇文章主要给大家介绍了关于如何修改覆盖spring boot默认日志策略logback的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-10-10
  • Java多线程下载的实现方法

    Java多线程下载的实现方法

    复习多线程的时候,练习了下,顺便记录一下:
    2013-03-03

最新评论