Java学习十二—Java8特性之Optional类

news2025/1/24 22:47:05

一、简介

Java 8 引入了 Optional​ 类作为一种容器,可以用来显式地表示一个值存在或不存在。它解决了传统上可能会遇到的空指针异常问题,同时提供了一种更优雅的方式来处理可能为null的情况。

image222

Java 8 中引入 Optional​ 类的背景可以从以下几个方面来理解:

  1. 空指针异常问题: 在 Java 中,空指针异常(NullPointerException)是一个常见的问题,特别是当处理可能为null的对象时。这种异常可能会在运行时导致程序崩溃,难以调试和处理。
  2. 编程语言发展趋势: 在 Java 8 发布之前,其他一些现代编程语言(如Scala、Swift等)已经引入了类似的 Option 类型或者可空类型(Nullable Type),这些类型可以更安全和清晰地处理可能为空的值。
  3. 函数式编程的影响: Java 8 引入了函数式编程的元素,例如 lambda 表达式和流式 API。在函数式编程中,避免副作用和空值处理是重要的理念之一,因此需要一种适合函数式编程风格的空值处理机制。
  4. 更优雅的代码风格: 使用 Optional​ 类可以使代码更加清晰和优雅。通过强制显式处理可能为null的情况,可以减少条件判断和嵌套,提高代码的可读性和可维护性。
  5. API 设计的进步: 引入 Optional​ 类使得 Java 标准库的 API 设计更加完善和一致。在一些情况下,例如集合操作中的元素查找或者返回值可能为空的方法,使用 Optional​ 可以更准确地表达返回值的可能性。

综上所述,Java 8 引入 Optional​ 类旨在提供一种更加安全、清晰和优雅的方式来处理可能为null的值,以及促进函数式编程风格在 Java 中的应用。

二、类申明

public final class Optional<T> 

image

三、方法

以下是 Optional​ 类的一些常用方法:

  1. Optional.of(T value) ​ - 创建一个 Optional​ 实例,其非空值由给定的参数指定。如果给定的参数为 null​,则抛出 NullPointerException​。
  2. Optional.ofNullable(T value) ​ - 创建一个 Optional​ 实例,其值可以是 null​。如果给定的参数为 null​,则返回一个空的 Optional​ 对象。
  3. Optional.empty() ​ - 返回一个空的 Optional​ 实例。
  4. Optional.isPresent() ​ - 检查 Optional​ 是否包含非空值。如果包含非空值,则返回 true​,否则返回 false​。
  5. Optional.ifPresent(Consumer<? super T> consumer) ​ - 如果 Optional​ 包含非空值,则将该值传递给提供的 Consumer​ 对象。如果 Optional​ 是空的,则不执行任何操作。
  6. Optional.orElse(T other) ​ - 如果 Optional​ 包含非空值,则返回该值;否则返回提供的其他值。
  7. Optional.orElseGet(Supplier<? extends T> other) ​ - 如果 Optional​ 包含非空值,则返回该值;否则返回由 Supplier​ 调用返回的值。
  8. Optional.orElseThrow() ​ - 如果 Optional​ 包含非空值,则返回该值;否则抛出 NoSuchElementException​。
  9. Optional.map(Function<? super T,? extends U> mapper) ​ - 如果 Optional​ 包含非空值,则将该值传递给提供的 Function​ 对象,并返回结果包装在 Optional​ 中。如果 Optional​ 是空的,则返回空的 Optional​。
  10. Optional.flatMap(Function<? super T, Optional<? extends U>> mapper) ​ - 如果 Optional​ 包含非空值,则将该值传递给提供的 Function​ 对象,并返回 Function​ 返回的 Optional​。如果 Optional​ 是空的,或者 Function​ 返回空的 Optional​,则返回空的 Optional​。
  11. Optional.filter(Predicate<? super T> predicate) ​ - 如果 Optional​ 包含非空值,并且该值满足提供的 Predicate​,则返回包含该值的 Optional​。如果 Optional​ 是空的,或者非空值不满足 Predicate​,则返回空的 Optional​。

四、示例

4.1示例1

Optional<String> optional = Optional.of("bam");

optional.isPresent();           // true
optional.get();                 // "bam"
optional.orElse("fallback");    // "bam"

optional.ifPresent((s) -> System.out.println(s.charAt(0)));     // "b"

4.2示例2

创建 Optional 对象:

  • of(T value) 创建一个包含指定非null值的 Optional。

    Optional<String> optional = Optional.of("Hello");
    
  • ofNullable(T value) 创建一个可能为null的 Optional 对象。

    String str = null;
    Optional<String> optional = Optional.ofNullable(str);
    
  • empty() 创建一个空的 Optional 对象。

    Optional<String> optional = Optional.empty();
    

判断值是否存在:

  • isPresent() 如果存在值,则返回true,否则返回false。

    Optional<String> optional = Optional.of("Hello");
    if (optional.isPresent()) {
        // 值存在时的操作
        System.out.println("Value is present: " + optional.get());
    } else {
        // 值不存在时的操作
        System.out.println("Value is absent.");
    }
    

获取值或默认值:

  • get() 如果存在值,则返回该值,否则抛出 NoSuchElementException​。

    Optional<String> optional = Optional.of("Hello");
    String value = optional.get();
    
  • orElse(T other) 如果存在值,则返回该值,否则返回指定的默认值。

    Optional<String> optional = Optional.ofNullable(null);
    String result = optional.orElse("Default Value");
    
  • orElseGet(Supplier<? extends T> other) 如果存在值,则返回该值,否则使用提供的 Supplier 生成一个默认值。

    Optional<String> optional = Optional.ofNullable(null);
    String result = optional.orElseGet(() -> "Default Value");
    

条件式操作:

  • filter(Predicate<? super T> predicate) 如果存在值并且满足给定条件,则返回包含该值的 Optional,否则返回空的 Optional。

    Optional<String> optional = Optional.of("Hello");
    Optional<String> filtered = optional.filter(s -> s.startsWith("H"));
    
  • map(Function<? super T, ? extends U> mapper) 如果存在值,则对其进行转换,并返回包含转换后值的 Optional,否则返回空的 Optional。

    Optional<String> optional = Optional.of("Hello");
    Optional<String> upperCase = optional.map(String::toUpperCase);
    
  • flatMap(Function<? super T, Optional<U>> mapper) 如果存在值,则对其进行转换并返回结果,否则返回空的 Optional。

    Optional<String> optional = Optional.of("Hello");
    Optional<String> flatMapped = optional.flatMap(s -> Optional.of(s + " World"));
    

条件式执行:

  • ifPresent(Consumer<? super T> consumer) 如果存在值,则执行指定的操作。

    Optional<String> optional = Optional.of("Hello");
    optional.ifPresent(s -> System.out.println("Value is present: " + s));
    

示例:

import java.util.Optional;

public class OptionalExample {
    public static void main(String[] args) {
        // 创建一个非空的 Optional
        Optional<String> optional1 = Optional.of("Hello");

        // 创建一个可能为 null 的 Optional
        String str = null;
        Optional<String> optional2 = Optional.ofNullable(str);

        // 判断值是否存在
        if (optional1.isPresent()) {
            System.out.println("Value 1 is present: " + optional1.get());
        } else {
            System.out.println("Value 1 is absent.");
        }

        // 使用 orElse 方法提供默认值
        String result = optional2.orElse("Default Value");
        System.out.println("Value 2: " + result);

        // 使用 map 对值进行转换
        Optional<String> upperCaseOptional = optional1.map(String::toUpperCase);
        upperCaseOptional.ifPresent(s -> System.out.println("Uppercase value: " + s));

        // 使用 flatMap 进行链式操作
        Optional<String> flatMapped = optional1.flatMap(s -> Optional.of(s + " World"));
        flatMapped.ifPresent(s -> System.out.println("FlatMapped value: " + s));
    }
}

image

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

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

相关文章

css flex 子元素溢出时,父元素被撑开解决方案

当父元素使用flex: 1;自适应填满时&#xff0c;子元素内容溢出&#xff0c;父元素内容撑大&#xff0c;导致页面显示问题&#xff0c;或设置了overflow 为scroll 的元素没出现滚动条等问题 解决方案&#xff1a; 1.如果是横向排列&#xff0c;flex: 1;的元素加上width: 0; 此…

【Matlab 路径优化】基于蚁群算法的XX市旅游景点线路优化系统

基于蚁群算法的XX市旅游景点线路优化系统 &#xff08;一&#xff09;客户需求&#xff1a; ①考虑旅游景点的空间分布、游客偏好等因素&#xff0c;实现了旅游线路的智能规划 ②游客选择一景点出发经过所要游览的所有景点只一次&#xff0c;最后回到出发点的前提下&#xf…

实验4 宏指令及子程序设计实验

从键盘输入10个无符号十进制数&#xff08;小于256&#xff09;&#xff0c;将其转换为二进制数并存放在NUM字节型变量中&#xff0c;找出其中的最大数&#xff0c;并将找出的最大数在屏幕上显示出来。 要求&#xff1a; 1&#xff09;在屏幕上显示字符串提示信息的功能由宏指…

【PB案例学习笔记】-28制作一个右键菜单

写在前面 这是PB案例学习笔记系列文章的第28篇&#xff0c;该系列文章适合具有一定PB基础的读者。 通过一个个由浅入深的编程实战案例学习&#xff0c;提高编程技巧&#xff0c;以保证小伙伴们能应付公司的各种开发需求。 文章中设计到的源码&#xff0c;小凡都上传到了gite…

多态相关知识2

多态相关知识2 抽象基类和纯虚函数纯虚函数和多继承虚析构函数虚析构函数作用纯虚析构函数 重写 重载 重定义 抽象基类和纯虚函数 在设计时&#xff0c;常常希望基类仅仅作为其派生类的一个接口。这就是说&#xff0c;仅想对基类进行向上类型转换&#xff0c;使用它的接口&…

Wing FTP Server

文章目录 1.Wing FTP Server简介1.1主要特点1.2使用教程 2.高级用法2.1Lua脚本,案例1 1.Wing FTP Server简介 Wing FTP Server&#xff0c;是一个专业的跨平台FTP服务器端&#xff0c;它拥有不错的速度、可靠性和一个友好的配置界面。它除了能提供FTP的基本服务功能以外&#…

据阿谱尔APO Research统计,2023年全球皮肤科药物市场价值为 751.7 亿美元

据阿谱尔 (APO Research&#xff09;统计&#xff0c;2023 年全球皮肤科药物市场价值估计为 751.7 亿美元&#xff0c;预计到 2030 年将达到 1622.1 亿美元&#xff0c;预测期内&#xff08;2024-2030 年&#xff09;的复合年增长率为 11.44%。 全球最大的单一类别皮肤科药物是…

TheBrain 14:AI增强的视觉知识管理工具

TheBrain是一款与众不同的思维导图软件&#xff0c;其所有信息通过一个又一个的节点进行联系&#xff0c;最终形成一个杂而不乱的网状结构。与传统的树形思维导图相较而言&#xff0c;TheBrain更有助于整合零散的资源&#xff0c;激发创意和锻炼思维。此次thebrain13带来了很多…

基因组学系列3:基因分型Phasing与单倍型参考序列HRC

1. 基因分型Phasing概念 基因分型&#xff0c;也称为基因定相、单倍体分型、单倍体构建等&#xff0c;即将一个二倍体&#xff08;或多倍体&#xff09;基因组上的等位基因&#xff08;或杂合位点&#xff09;正确定位到父亲或母亲的染色体上&#xff0c;最终使得来自同一亲本…

HMI 的 UI 风格成就经典

HMI 的 UI 风格成就经典

【自动驾驶仿真在做什么——初学者总结(陆续补充)】

文章目录 基础概念自动驾驶级别再稍提一下ODD是什么&#xff1f; 自动驾驶仿真分类软件在环仿真硬件仿真 仿真究竟难在哪&#xff1f;一些名词解释 最近也是学习自动驾驶仿真相关知识&#xff0c;习惯去总结一下&#xff0c;方便自己回顾和总结&#xff0c;主要包括了自动驾驶框…

登 Cell 子刊!清华大学张强锋课题组开发 SPACE 算法,组织模块发现能力领先同类工具

多细胞生物中的细胞尽管共享相同的基因组&#xff0c;但因其内部基因调控网络的差异以及与周围微环境中相邻细胞的外部信号交流&#xff0c;使得它们在形态、基因表达和功能上展现出显著的多样性。为了将细胞类型信息与其在组织内的空间位置相关联&#xff0c;空间转录组学 (Sp…

OpenLCA、GREET、R语言的生命周期评价方法、模型构建

原文链接&#xff1a;OpenLCA、GREET、R语言的生命周期评价方法、模型构建教程https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247608240&idx6&sn1b5758206d500399fe7cc69e800f61fe&chksmfa826657cdf5ef413d31557941a1c5db5cc84bba8d0f408c469e05a4118c…

软考的报名详细流程

2024年软考的考试时间已经公布&#xff0c;分别为5月25日至28日和11月9日至12日。准备参加2024年软考的朋友们&#xff0c;一定要提前关注官方发布的考试安排。 本文将详细介绍软考报考的整个流程。准备报考的朋友们&#xff0c;阅读本文就足够啦&#xff01;软考的报考流程大致…

Vant Design - VUE 时间区间限制

效果图&#xff0c;限制7天 实现代码 <a-range-picker v-model"dateTime" style"width: 100%" :disabled-date"disabledDate" format"YYYY-MM-DD HH:mm:ss" :showTime"true" :placeholder"[开始时间, 结束时间]&quo…

Vue 解决报错 VM6290:1 Uncaught SyntaxError: Unexpected identifier ‘Promise‘

Vue 报错 VM6290:1 Uncaught SyntaxError: Unexpected identifier ‘Promise’ 排查 控制台报了一个错误 , Uncaught SyntaxError: Unexpected identifier ‘Promise’&#xff0c;网上查到的方法是 缺少符号&#xff0c;语法写法错误&#xff0c;但这些都没有解决我的问题&am…

Simulink 模型生成 C 代码(三):将模型参数配置为全局变量以在运行时调整

默认情况下&#xff0c;代码生成优化可避免存储不参与入口函数接口的模型参数和大多数信号。要使参数可调和相关信号可访问&#xff0c;请通过显式配置方式来标识它们。 在模型 RollAxisAutopilot 的 BasicRollMode 子系统中&#xff0c;将 PID 控制参数配置为在代码中显示为可…

VMware Workstation桥接模式无法上网

问题背景 我之前创建过一个虚拟机&#xff0c;当时虚拟机的网络模式使用的是桥接模式&#xff0c;配置好了固定ip地址&#xff0c;是可以正常上网的&#xff0c;中间没有做任何网络上面的配置。但是今天再打开这台虚拟机时&#xff0c;发现竟然不能上网了。 物理主机的ip信息配…

构造函数深入理解

目录 构造函数构造函数体赋值初始化列表初始化列表格式初始化列表的意义以及注意点const修饰的成员变量初始化对象成员具体初始化的地方缺省值存在的意义例子1例子2 初始化与赋值引用成员变量的初始化注意点1注意点2我的疑惑 自定义类型成员初始化例子1例子2例子3例子4 初始化列…

JAVA小知识31:多线程篇2

一、等待唤醒机制 生产者和消费者&#xff0c;也叫等待唤醒机制。他是一个十分经典的多线程协作的模式。我们来讲一个小故事&#xff1a; 在一个繁忙的工厂里&#xff0c;有一个生产线&#xff0c;我们称之为“共享资源”。这个生产线一次只能生产一个产品&#xff0c;而且需要…