Java中的Lambda表达式

简介: Java中的Lambda表达式

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

    @Test
    public void test1(){
    

        //匿名实现类的非匿名对象
        Runnable runnable = new Runnable(){
    

            @Override
            public void run() {
    
                System.out.println("This is test");
            }
        };

        runnable.run();


        //Lambda表达式
        Runnable runnable1 = () -> System.out.println("This is test");

        runnable1.run();
    }

输出结果:

This is test
This is test

Process finished with exit code 0

相信初学者看到这里会有所不明白,那么下面我们将详细说明Lambda表达式。

一.Lambda表达式的语法

在Java 8 语言中引入了一种新的语法元素和操作符。这个操作符为 “->” , 该操作符被称为 Lambda 操作符或箭头操作符。它将 Lambda 分为两个部分:

左侧:指定了 Lambda 表达式需要的参数列表右侧:指定了 Lambda 体,是抽象方法的实现逻辑,也即 Lambda 表达式要执行的功能。

Lambda表达式的本质是作为函数式接口的实例。

1. 无参,无返回值

    @Test
    public void test1(){
      
        Runnable runnable = new Runnable() {
      

            @Override
            public void run() {
      
                System.out.println("This is test!!!");
            }
        };

        //1. 无参,无返回值
        Runnable runnable1 = () -> {
      
            System.out.println("This is test!");
        };
    }

2.有一个参数,但是没有返回值。

    @Test
    public void test2(){
       

        Consumer<String> consumer = new Consumer<>() {
       

            @Override
            public void accept(String s) {
       
                System.out.println(s);
            }
        };

        //2.有一个参数,但是没有返回值。
        Consumer<String> consumer1 = (String s) -> {
       
            System.out.println(s);
        };
    } 

3.数据类型可以省略,因为可由编译器推断得出(类型推断)

    @Test
    public void test2(){
        

        Consumer<String> consumer = new Consumer<>() {
        

            @Override
            public void accept(String s) {
        
                System.out.println(s);
            }
        };

        //2.有一个参数,但是没有返回值。
        Consumer<String> consumer1 = (String s) -> {
        
            System.out.println(s);
        };

        //3.数据类型可以省略,因为可由编译器推断得出(类型推断)
        Consumer<String> consumer2 = (s) -> {
        
            System.out.println(s);
        };
    }

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

 @Test public void test2(){
          Consumer<String> consumer = new Consumer<>() {
          @Override public void accept(String s) {
          System.out.println(s); } }; //2.有一个参数,但是没有返回值。 Consumer<String> consumer1 = (String s) -> {
          System.out.println(s); }; //3.数据类型可以省略,因为可由编译器推断得出(类型推断) Consumer<String> consumer2 = (s) -> {
          System.out.println(s); }; //4.Lambda 若只需要一个参数时,参数的小括号可以省略 Consumer<String> consumer3 = s ->{
          System.out.println(s); }; } 

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

 @Test public void test3(){
           Comparator<Integer> comparator = new Comparator<>() {
           @Override public int compare(Integer o1, Integer o2) {
           System.out.println("函数式接口方法!"); return Integer.compare(o1, o2); } }; //5.Lambda 需要两个或以上的参数,多条执行语句,并且可以有返回值 Comparator<Integer> comparator1 = (x,y) -> {
           System.out.println("函数式接口方法!"); return Integer.compare(x,y); }; } 

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

 @Test public void test3(){
            Comparator<Integer> comparator = new Comparator<>() {
            @Override public int compare(Integer o1, Integer o2) {
            System.out.println("函数式接口方法!"); return Integer.compare(o1, o2); } }; //5.Lambda 需要两个或以上的参数,多条执行语句,并且可以有返回值 Comparator<Integer> comparator1 = (x,y) -> {
            System.out.println("函数式接口方法!"); return Integer.compare(x,y); }; //6.当 Lambda 体只有一条语句时,return 与大括号若有,都可以省略 // 6.1 Comparator<Integer> comparator2 = (x,y) -> {
            return Integer.compare(x,y); }; //6.2  Comparator<Integer> comparator3 = (x,y) -> Integer.compare(x,y); } 
 @Test public void test2(){
             Consumer<String> consumer = new Consumer<>() {
             @Override public void accept(String s) {
             System.out.println(s); } }; //2.有一个参数,但是没有返回值。 Consumer<String> consumer1 = (String s) -> {
             System.out.println(s); }; //3.数据类型可以省略,因为可由编译器推断得出(类型推断) Consumer<String> consumer2 = (s) -> {
             System.out.println(s); }; //4.Lambda 若只需要一个参数时,参数的小括号可以省略 Consumer<String> consumer3 = s ->{
             System.out.println(s); }; //6.当 Lambda 体只有一条语句时,return 与大括号若有,都可以省略 Consumer<String> consumer4 = s -> System.out.println(s); } 

二.类型推断说明

上述 Lambda 表达式中的参数类型都是由编译器推断得出的。Lambda 表达式中无需指定类型,程序依然可以编译,这是因为 javac 根据程序的上下文,在后台推断出了参数的类型。Lambda 表达式的类型依赖于上下文环境,是由编译器推断出来的。这就是所谓的“类型推断”。
例如:

Consumer<String> consumer = new Consumer<>() {
              @Override public void accept(String s) {
              System.out.println(s); } }; //数据类型可以省略,因为可由编译器推断得出(类型推断) Consumer<String> consumer2 = (s) -> {
              System.out.println(s); }; 

三.Lambda表达式与函数式接口

Java从诞生日起就是一直倡导“一切皆对象”,在Java里面面向对象(OOP) 编程是一切。但是随着python、scala等语言的兴起和新技术的挑战,Java不 得不做出调整以便支持更加广泛的技术要求,也即java不但可以支持OOP还 可以支持OOF(面向函数编程)。在函数式编程语言当中,函数被当做一等公民对待。在将函数作为一等公民的 编程语言中,Lambda表达式的类型是函数。但是在Java8中,有所不同。在 Java8中,Lambda表达式是对象,而不是函数,它们必须依附于一类特别的 对象类型——函数式接口。简单的说,在Java8中,Lambda表达式就是一个函数式接口的实例。这就是 Lambda表达式和函数式接口的关系。也就是说,只要一个对象是函数式接口的实例,那么该对象就可以用Lambda表达式来表示。所以以前用匿名实现类表示的现在都可以用Lambda表达式来写。
目录
相关文章
|
2月前
|
Java API 开发者
Java中的Lambda表达式与Stream API的协同作用
在本文中,我们将探讨Java 8引入的Lambda表达式和Stream API如何改变我们处理集合和数组的方式。Lambda表达式提供了一种简洁的方法来表达代码块,而Stream API则允许我们对数据流进行高级操作,如过滤、映射和归约。通过结合使用这两种技术,我们可以以声明式的方式编写更简洁、更易于理解和维护的代码。本文将介绍Lambda表达式和Stream API的基本概念,并通过示例展示它们在实际项目中的应用。
|
3月前
|
Java API 开发者
Java中的Lambda表达式:简洁代码的利器####
本文探讨了Java中Lambda表达式的概念、用途及其在简化代码和提高开发效率方面的显著作用。通过具体实例,展示了Lambda表达式如何在Java 8及更高版本中替代传统的匿名内部类,使代码更加简洁易读。文章还简要介绍了Lambda表达式的语法和常见用法,帮助开发者更好地理解和应用这一强大的工具。 ####
|
3月前
|
并行计算 Java 编译器
深入理解Java中的Lambda表达式
在Java 8中引入的Lambda表达式,不仅简化了代码编写,还提升了代码可读性。本文将带你探索Lambda表达式背后的逻辑与原理,通过实例展示如何高效利用这一特性优化你的程序。
|
3月前
|
搜索推荐 Java API
探索Java中的Lambda表达式
本文将深入探讨Java 8引入的Lambda表达式,这一特性极大地简化了代码编写,提高了程序的可读性。通过实例分析,我们将了解Lambda表达式的基本概念、使用场景以及如何优雅地重构传统代码。文章不仅适合初学者,也能帮助有经验的开发者加深对Lambda表达式的理解。
|
2月前
|
安全 Java API
Java中的Lambda表达式:简化代码的现代魔法
在Java 8的发布中,Lambda表达式的引入无疑是一场编程范式的革命。它不仅让代码变得更加简洁,还使得函数式编程在Java中成为可能。本文将深入探讨Lambda表达式如何改变我们编写和维护Java代码的方式,以及它是如何提升我们编码效率的。
|
3月前
|
安全 Java API
Java中的Lambda表达式与Stream API的高效结合####
探索Java编程中Lambda表达式与Stream API如何携手并进,提升数据处理效率,实现代码简洁性与功能性的双重飞跃。 ####
44 0
|
3月前
|
Java 开发者
探索Java中的Lambda表达式
【10月更文挑战第43天】本文将深入浅出地介绍Java中的Lambda表达式,通过实际代码示例,带领读者理解其背后的原理及应用场景。Lambda表达式不仅简化了代码,还提高了开发效率,是Java开发者必备的技能之一。
|
Java
QuartZ Cron表达式在java定时框架中的应用
CronTrigger CronTriggers往往比SimpleTrigger更有用,如果您需要基于日历的概念,而非SimpleTrigger完全指定的时间间隔,复发的发射工作的时间表。 CronTrigger,你可以指定触发的时间表如“每星期五中午”,或“每个工作日9:30时”,甚至“每5分钟一班9:00和10:00逢星期一上午,星期三星期五“。
1115 0
|
3天前
|
Java 程序员 开发者
Java社招面试题:一个线程运行时发生异常会怎样?
大家好,我是小米。今天分享一个经典的 Java 面试题:线程运行时发生异常,程序会怎样处理?此问题考察 Java 线程和异常处理机制的理解。线程发生异常,默认会导致线程终止,但可以通过 try-catch 捕获并处理,避免影响其他线程。未捕获的异常可通过 Thread.UncaughtExceptionHandler 处理。线程池中的异常会被自动处理,不影响任务执行。希望这篇文章能帮助你深入理解 Java 线程异常处理机制,为面试做好准备。如果你觉得有帮助,欢迎收藏、转发!
37 14
|
6天前
|
安全 Java 程序员
Java 面试必问!线程构造方法和静态块的执行线程到底是谁?
大家好,我是小米。今天聊聊Java多线程面试题:线程类的构造方法和静态块是由哪个线程调用的?构造方法由创建线程实例的主线程调用,静态块在类加载时由主线程调用。理解这些细节有助于掌握Java多线程机制。下期再见! 简介: 本文通过一个常见的Java多线程面试题,详细讲解了线程类的构造方法和静态块是由哪个线程调用的。构造方法由创建线程实例的主线程调用,静态块在类加载时由主线程调用。理解这些细节对掌握Java多线程编程至关重要。
35 13