Java 8 新特性:深入理解 Lambda 表达式的强大与应用

Java 8 新特性:深入理解 Lambda 表达式的强大与应用

Lambda 表达式是 Java 8 引入的重要特性之一,它允许将匿名函数(即无名称的函数)作为参数传递给方法,简化了代码的编写,使代码更加简洁和易读。本文将深入探讨 Lambda 表达式的原理、语法、使用场景及其在实际编程中的应用。

1. Lambda 表达式的基本语法

Lambda 表达式的基本语法形式如下:

(parameters) -> expression
或者
(parameters) -> { statements; }

示例

// 无参数,返回固定值
() -> 42// 单个参数,返回其平方
x -> x * x// 多个参数,返回它们的和
(x, y) -> x + y// 带有块语句
(x, y) -> {int sum = x + y;return sum;
}

2. 基本使用示例

示例:简单的 Lambda 表达式

import java.util.function.Consumer;public class LambdaBasicExample {public static void main(String[] args) {// 使用 Lambda 表达式打印消息Consumer<String> printMessage = message -> System.out.println(message);printMessage.accept("Hello, Lambda!");}
}

3. 集合操作

示例:列表排序

import java.util.Arrays;
import java.util.List;public class LambdaSortExample {public static void main(String[] args) {List<String> names = Arrays.asList("Peter", "Anna", "Mike", "Xenia");// 使用 Lambda 表达式排序列表names.sort((a, b) -> a.compareTo(b));System.out.println(names); // 输出:[Anna, Mike, Peter, Xenia]}
}

更全,更详细的集合操作,请参考:深入探讨 Java 8 集合操作:全面解析 Stream API 的强大功能

示例:过滤和映射

import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;public class LambdaFilterMapExample {public static void main(String[] args) {List<String> names = Arrays.asList("Peter", "Anna", "Mike", "Xenia");// 使用 Lambda 表达式过滤并映射List<String> result = names.stream().filter(name -> name.startsWith("P")).map(String::toUpperCase).collect(Collectors.toList());System.out.println(result); // 输出:[PETER]}
}

4. 使用自定义函数式接口

Lambda 表达式通常与函数式接口一起使用。函数式接口是只有一个抽象方法的接口,可以用 @FunctionalInterface 注解来标识。
示例

@FunctionalInterface
interface Converter<F, T> {T convert(F from);
}public class LambdaCustomInterfaceExample {public static void main(String[] args) {Converter<String, Integer> converter = (from) -> Integer.valueOf(from);Integer converted = converter.convert("123");System.out.println(converted); // 输出:123}
}

5. 并发编程

示例:创建线程

public class LambdaThreadExample {public static void main(String[] args) {// 使用 Lambda 表达式创建线程new Thread(() -> {for (int i = 0; i < 5; i++) {System.out.println("Hello from thread " + Thread.currentThread().getName());}}).start();}
}

示例:使用 CompletableFuture

import java.util.concurrent.CompletableFuture;public class LambdaCompletableFutureExample {public static void main(String[] args) {CompletableFuture.supplyAsync(() -> "Hello").thenApply(result -> result + " World").thenAccept(result -> System.out.println(result)); // 输出:Hello World}
}

6. 高阶函数

示例:接受 Lambda 表达式作为参数

import java.util.function.Function;public class HigherOrderFunctionExample {public static void main(String[] args) {Function<Integer, Integer> square = x -> x * x;System.out.println(applyFunction(5, square)); // 输出:25}public static <T, R> R applyFunction(T input, Function<T, R> function) {return function.apply(input);}
}

示例:返回 Lambda 表达式

import java.util.function.Function;public class HigherOrderFunctionExample {public static void main(String[] args) {Function<Integer, Integer> adder = createAdder(10);System.out.println(adder.apply(5)); // 输出:15}public static Function<Integer, Integer> createAdder(int addend) {return x -> x + addend;}
}

7. 捕获局部变量

示例

public class LambdaVariableCaptureExample {public static void main(String[] args) {final int num = 1;Converter<Integer, String> stringConverter = (from) -> String.valueOf(from + num);System.out.println(stringConverter.convert(2)); // 输出:3}public interface Converter<F, T> {T convert(F from);}
}

8. 方法引用

示例:静态方法引用

import java.util.Arrays;
import java.util.List;public class StaticMethodReferenceExample {public static void main(String[] args) {List<Integer> numbers = Arrays.asList(3, 2, 1);// 使用静态方法引用排序列表numbers.sort(Integer::compare);System.out.println(numbers); // 输出:[1, 2, 3]}
}

示例:实例方法引用

import java.util.Arrays;
import java.util.List;public class InstanceMethodReferenceExample {public static void main(String[] args) {List<String> names = Arrays.asList("Peter", "Anna", "Mike", "Xenia");// 使用实例方法引用names.forEach(System.out::println);}
}

9. 构造函数引用

示例

import java.util.function.Function;class Person {private String name;public Person(String name) {this.name = name;}public String getName() {return name;}
}public class ConstructorReferenceExample {public static void main(String[] args) {// 使用构造函数引用Function<String, Person> personFactory = Person::new;Person person = personFactory.apply("John");System.out.println(person.getName()); // 输出:John}
}

10. 使用 Optional

示例:避免空指针异常

import java.util.Optional;public class LambdaOptionalExample {public static void main(String[] args) {Optional<String> optional = Optional.of("Hello");// 使用 Lambda 表达式处理 Optionaloptional.ifPresent(System.out::println); // 输出:Hello}
}

11. 自定义排序逻辑

示例

import java.util.Arrays;
import java.util.Comparator;
import java.util.List;public class LambdaCustomSortExample {public static void main(String[] args) {List<String> names = Arrays.asList("Peter", "Anna", "Mike", "Xenia");// 自定义排序逻辑names.sort((a, b) -> {int lengthCompare = Integer.compare(a.length(), b.length());if (lengthCompare != 0) {return lengthCompare;}return a.compareTo(b);});System.out.println(names); // 输出:[Anna, Mike, Peter, Xenia]}
}

12. 复杂场景中的 Lambda 表达式

Lambda 表达式不仅可以用于简单的集合操作,还可以用于更复杂的场景,如事件处理、GUI 编程等。
示例:事件处理

import javax.swing.*;
import java.awt.event.ActionEvent;public class LambdaEventHandlerExample {public static void main(String[] args) {JFrame frame = new JFrame("Lambda Example");JButton button = new JButton("Click Me");// 使用 Lambda 表达式添加事件监听器button.addActionListener(event -> System.out.println("Button clicked"));frame.add(button);frame.setSize(200, 200);frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);frame.setVisible(true);}
}

总结

Lambda 表达式不仅简化了代码,还使 Java 具备了函数式编程的能力。通过上述示例,可以更好地理解 Java 8 的 Lambda 表达式及其应用场景。Lambda 表达式不仅简化了代码,还使 Java 具备了函数式编程的能力。掌握 Lambda 表达式及其相关的新特性,可以显著提高代码的简洁性和可维护性,并且在集合操作、并发编程、事件处理等场景中发挥重要作用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/15762.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Next.js里app和pages文件夹的区别

最近开始学 Next.js&#xff0c;因为纯自学&#xff0c;有时候网上找到的学习资料都是几年前的&#xff0c;难免会有点 outdated&#xff0c;因此当自己创建的项目结构和视频里呈现的结构不一致时&#xff0c;难免会有点困惑。 例如&#xff0c;今天遇到的第一个问题就是&…

CAD二次开发(2)-将直线对象添加到CAD图形文件

1. 准备工作 创建一个类库项目&#xff0c;如下&#xff1a; 2. 分析Line对象 Line类的初始化方法和参数 using Autodesk.AutoCAD.DatabaseServices; Line line new Line();Line 继承Curve 继承Entity 继承DBObject 继承Drawable 继承RXObject 初始化方法有两个&#xf…

大模型分布式训练并行技术分享

目前业内解决大模型问题&#xff0c;基本以多节点、分布式方案为主。分布式方案具体的实施时&#xff0c;又分为数据并行、参数并行、流水线并行等&#xff0c;针对具体的业务场景采取合适的并行方案方可带来更高的效率。 后续结合业内主流的分布式框架&#xff0c;具体介绍各种…

数据库(5)——DDL 表操作

表查询 先要进入到某一个数据库中才可使用这些指令。 SHOW TABLES; 可查询当前数据库中所有的表。 表创建 CREATE TABLE 表名( 字段1 类型 [COMMENT 字段1注释] ...... 字段n 类型 [COMMENT 字段n注释] )[COMMENT 表注释]; 例如&#xff0c;在student数据库里创建一张studen…

网络安全等级保护:正确配置 Linux

正确配置 Linux 对Linux安全性的深入审查确实是一项漫长的任务。原因之一是Linux设置的多样性。用户可以使用Debian、Red Hat、Ubuntu或其他Linux发行版。有些可能通过shell工作&#xff0c;而另一些则通过某些图形用户界面&#xff08;例如 KDE 或 GNOME&#xff09;工作&…

APP安全测试汇总【网络安全】

APP安全测试汇总 一.安装包签名和证书 1.问题说明 检测 APP 移动客户端是否经过了正确签名&#xff0c;通过检测签名&#xff0c;可以检测出安装包在签名后是否被修改过。如 果 APP 使⽤了 debug 进⾏证书签名&#xff0c;那么 APP 中⼀部分 signature 级别的权限控制就会失效…

Unity 生成物体的几种方式

系列文章目录 unity工具 文章目录 系列文章目录前言&#x1f449;一、直接new的方式创建生成1-1.代码如下1-2. 效果图 &#x1f449;二、使用Instantiate创建生成&#xff08;GameObject&#xff09;2-1.代码如下2-2.效果如下图 &#x1f449;三.系统CreatePrimitive创建生成3…

Java 18 的应用

Java 18的发布时间是2022年3月22日。这个版本带来了许多新的特性和改进&#xff0c;包括模式匹配增强、协程支持、SIMD指令支持等&#xff0c;这些功能为开发人员提供了更多的灵活性和控制力&#xff0c;有助于他们构建出更高效、可靠的应用程序。 Java 18 的新功能为多种应用…

nodejs设置强制缓存,协商缓存

协商缓存&#xff08;Conditional Requests&#xff09; 协商缓存指的是浏览器每次请求时携带上次请求标识&#xff08;如 Last-Modified 或 ETag&#xff09;&#xff0c;服务器通过这些标识判断资源是否修改&#xff0c;如果没有修改&#xff0c;则返回 304 Not Modified 响…

数据结构之栈和队列(超详解

目录 一.栈 1.栈的基本概念 2.栈的基本操作 3.栈的储存结构 ①栈的顺序储存 (1)基本概念 (2)代码实现 ②栈的链式储存 (1)基本概念 (2)代码实现 二.队列 1.队列的基本概念 2.队列的基本操作 3.队列的储存结构 ①队列的链式储存 (1)基本概念 ​编辑 (2)代码实现 ②…

关于回调函数Callback()

今天在写异步通信时发现少写了一个callback&#xff08;&#xff09;回调函数&#xff0c;因此一直无法执行&#xff0c;callback其实可以返回该函数的处理结果&#xff0c;返回的是true值&#xff0c;目前理解是这样&#xff0c;&#xff0c;对于需要验证的值要加上&#xff0…

Spring MVC+mybatis 项目入门:旅游网(一)项目创建与准备

个人博客&#xff1a;Spring MVCmybatis 项目入门:旅游网&#xff08;一&#xff09;项目创建与准备 | iwtss blog 先看这个&#xff01; 这是18年的文章&#xff0c;回收站里恢复的&#xff0c;现阶段看基本是没有参考意义的&#xff0c;技术老旧脱离时代&#xff08;2024年辣…

从0开始学统计-卡方检验

1.什么是卡方检验&#xff1f; 卡方检验是一种用于检验观察频数与期望频数之间差异的统计方法。它通常用于分析分类变量之间的关联性或独立性。在卡方检验中&#xff0c;我们将观察到的频数与期望频数进行比较&#xff0c;从而确定它们之间的差异是否显著。 卡方检验的基本思…

2024-05-23_结构体概念等作业

1.如有以下代码&#xff1a; struct student {int num;char name[32];float score; }stu;则下面的叙述不正确的是&#xff1a;( ) A.struct 是结构体类型的关键字 B.struct student 是用户定义的结构体类型 C.num, score 都是结构体成员名 D.stu 是用户定义的结构体类型名 解析…

【机器学习与大模型】驱动下的应用图像识别与处理

摘要&#xff1a; 本文深入探讨了机器学习在图像识别与处理领域的应用&#xff0c;特别是在大模型的推动下所取得的巨大进展。详细阐述了图像识别与处理的基本原理、关键技术&#xff0c;以及机器学习算法和大模型如何提升其性能和准确性。通过实际案例分析了其在多个领域的广泛…

Flink报错Checkpoint expired before completing

Flink报错Checkpoint expired before completing 报错日志&#xff1a; Failed to trigger or complete checkpoint 42 for job b5d4045c3f466fa91b29d74c5b123c25. (0 consecutive failed attempts so far) org.apache.flink.runtime.checkpoint.CheckpointException: Check…

uniapp实现下拉过滤查询列表

<picker bindchange"bindPickerChanges" value"{{selectedIndex}}"range"{{pickerArray}}"range-key"name"><view class"area-select">在线状态&#xff1a;<label for"">{{pickerArray[select…

虚机配置USB CDROM设备热迁移crash

虚机配置USB CDROM设备热迁移crash 问题现象定位过程堆栈分析日志分析打开trace异常日志上下文分析SpecificationCBWCSW 命令执行发送读命令读取数据 正常日志异常堆栈 修复方案结论 基础原理设备模型数据结构设备实例化 UHCIFrame ListTDQH SCSI 问题现象 dogfood环境一台虚机…

Haskell 的 自定义类型(data、type)

在 Haskell 中&#xff0c;type 和 data 关键字都用于定义新的数据类型&#xff0c;但它们有着不同的作用和语法。 一、type 关键字&#xff1a; 作用&#xff1a;type 关键字用于为已有类型创建别名&#xff0c;使得代码更易读和更具可读性。 语法&#xff1a;其语法为 type…

verilog中的task语句

task语句在Verilog和SystemVerilog中都能使用&#xff0c;但在SystemVerilog中它的功能更加强大&#xff0c;并且添加了一些新的特性。 module ExampleTask;// 定义任务task myTask;input [7:0] a, b;output [15:0] result;beginresult a b;endendtask// 主模块initial begin…