从 Java 8 Lambda 和 Stream 抛出已检查异常
与运行时异常不同,已检查异常需要在 Java 代码中进行显式处理。然而,在使用 lambda 表达式和流时,开发人员可能会遇到引发检查异常的挑战。本文探讨了在这些上下文中处理检查异常的限制和潜在的解决方案。
限制:
当前的 Java 8 语法没有提供直接抛出检查的机制流中使用的 lambda 表达式内的异常。以下代码片段演示了遇到的编译错误:
import java.util.List; import java.util.stream.Stream; public class CheckedStream { public List<class> getClasses() throws ClassNotFoundException { Stream.of("java.lang.Object", "java.lang.Integer", "java.lang.String") .map(className -> Class.forName(className)) .collect(Collectors.toList()); } }</class>
该问题源于流中使用的函数式接口(例如 Function 和 Stream)没有声明类型参数来支持抛出已检查异常。因此,编译器无法推断出精确的异常类型并报告编译错误。
Oracle 困境:
此功能的遗漏归因于在Java 8 的函数式接口设计。 Java 社区广泛批评 Oracle 的这一限制,许多人认为这是 API 中的一个重大错误,也是检查异常的一个缺点。
替代方案和解决方法:
虽然 Java 8 不直接支持从 lambda 抛出检查异常,但有一些解决方法可用:
1。在运行时异常中包装检查的异常:
此方法涉及在运行时异常中包装检查的异常,然后在 lambda 表达式中抛出包装的异常。
// Import the necessary class. import java.io.IOException; // Create a wrapper class to wrap checked exceptions. public class CheckedExceptionWrapper { public static void main(String[] args) { // Create a stream of strings. Stream<string> stream = Stream.of("file1.txt", "file2.txt", "file3.txt"); // Map the stream using a lambda that wraps checked exceptions. stream = stream.map(file -> { try { // Read the file. FileReader reader = new FileReader(file); reader.close(); return file; } catch (IOException e) { // Wrap the checked exception in a runtime exception. throw new RuntimeException(e); } }); // Collect the results. List<string> files = stream.collect(Collectors.toList()); } }</string></string>
2.使用已检查的供应商:
guava 库中的 CheckedSupplier 接口允许您创建抛出已检查异常的供应商。您可以使用此接口将检查的异常抛出代码包装在 lambda 表达式中。
// Import the necessary class. import com.google.common.base.CheckedSupplier; // Create a checked supplier that throws a checked exception. CheckedSupplier<string> supplier = () -> { // Code that throws a checked exception. throw new RuntimeException(); }; // Get the result from the supplier. try { String result = supplier.get(); } catch (Exception e) { // Handle the exception. }</string>
3.重写代码以避免使用检查异常:
不要使用检查异常,请考虑重写代码以以不同的方式处理错误。例如,您可以使用Optional类来表示可选值或抛出未经检查的异常并使用try-catch块处理它们。
4.使用 Catch 和 Throw 块:
这种方法很简单,但会使您的代码变得冗长且难以阅读。
// Example for Java 7 with try/catch try { // Code that throws a checked exception. throw new RuntimeException(); } catch (Exception e) { // Handle the exception. }
结论:
虽然 Java 8 的语法不直接支持从 lambda 和流抛出已检查异常,但有可用的解决方法。仔细考虑哪种方法适合您的具体情况。
以上是如何处理 Java 8 Lambda 和流引发的检查异常?的详细内容。更多信息请关注PHP中文网其他相关文章!

本文讨论了使用咖啡因和Guava缓存在Java中实施多层缓存以提高应用程序性能。它涵盖设置,集成和绩效优势,以及配置和驱逐政策管理最佳PRA

本文使用lambda表达式,流API,方法参考和可选探索将功能编程集成到Java中。 它突出显示了通过简洁性和不变性改善代码可读性和可维护性等好处

Java的类上载涉及使用带有引导,扩展程序和应用程序类负载器的分层系统加载,链接和初始化类。父代授权模型确保首先加载核心类别,从而影响自定义类LOA

本文讨论了使用JPA进行对象相关映射,并具有高级功能,例如缓存和懒惰加载。它涵盖了设置,实体映射和优化性能的最佳实践,同时突出潜在的陷阱。[159个字符]

本文讨论了使用Maven和Gradle进行Java项目管理,构建自动化和依赖性解决方案,以比较其方法和优化策略。

本文使用选择器和频道使用单个线程有效地处理多个连接的Java的NIO API,用于非阻滞I/O。 它详细介绍了过程,好处(可伸缩性,性能)和潜在的陷阱(复杂性,

本文使用Maven和Gradle之类的工具讨论了具有适当的版本控制和依赖关系管理的自定义Java库(JAR文件)的创建和使用。

本文详细介绍了用于网络通信的Java的套接字API,涵盖了客户服务器设置,数据处理和关键考虑因素,例如资源管理,错误处理和安全性。 它还探索了性能优化技术,我


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3汉化版
中文版,非常好用

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

禅工作室 13.0.1
功能强大的PHP集成开发环境

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

WebStorm Mac版
好用的JavaScript开发工具