《Java-SE-第三十四章》之Optional

news2024/10/2 12:19:51

前言

在你立足处深挖下去,就会有泉水涌出!别管蒙昧者们叫嚷:“下边永远是地狱!”

博客主页:KC老衲爱尼姑的博客主页

博主的github,平常所写代码皆在于此

共勉:talk is cheap, show me the code

作者是爪哇岛的新手,水平很有限,如果发现错误,一定要及时告知作者哦!感谢感谢!


文章目录

  • Optional介绍
    • Optional的构造方法
      • 1. Optional.of(T value)
      • 2. Optional.ofNullable(T value)
      • 3. Optional.empty()
    • 常用方法介绍
      • 1. ifPresent
      • 2. orElse
      • 3. orElseGet
      • 4. orElseThrow
      • 5. isPresent
      • 6. **map**

Optional介绍

我们平时写代码的时候遇到最多的异常就是空指针,所以很多时候就需要做各种非空判断,而过多的判断会导致代码臃肿,所以JDK8中引用了Optional,它是java.util包下的一个用于代替null 的一个工具类,使该类可以有效的避免空指针异常。

Optional的构造方法

Optional提供了三个静态方法来构造出一个Optional

1. Optional.of(T value)

该方法会接收一个非空的value来构造出optaional.返回的Opational包含value这个值。对于此方法的参数一定不能为null,否则会抛出空指针异常。

定义一个用户类便于后面使用

@Data
@AllArgsConstructor
public class User {
    private String username;
    private String password;
}

Optional.of演示使用


import org.example.Functional.model.User;

import java.util.Optional;

public class Demo7 {
    public static void main(String[] args) {
        User user = null;
        //无论传入方法的是不是null都不会出问题
        Optional<User> user1 = getUser();

    }
    
   private static Optional<User> getUser() {
       User user = new User("张三","12");
       //该方法传入的时候会抛出异常
       return Optional.of(null);
   }
}

运行结果:

给该方法传入null会报空指针异常,所以正确的使用是传非空的值


import org.example.Functional.model.User;

import java.util.Optional;


public class Demo7 {
    public static void main(String[] args) {
        User user = null;
        //无论传入方法的是不是null都不会出问题
        Optional<User> user1 = getUser();
        user1.ifPresent(user2 -> System.out.println(user2.getUsername()));//输出张三
    }

   private static Optional<User> getUser() {
       User user = new User("张三","12");
       //该方法传入null的时候会抛出异常
       return Optional.of(user);
   }
}

2. Optional.ofNullable(T value)

该方法和of的最大区别就是参数可以传入null

代码演示

import org.example.Functional.model.User;

import java.util.Optional;

public class Demo7 {
    public static void main(String[] args) {
        Optional<User> user = Optional.ofNullable(getUser());
        user.ifPresent(user2-> System.out.println(user2.getUsername()));//输出张三
        Optional<User> user2 = Optional.ofNullable(null);
        user2.ifPresent(user3-> System.out.println(user3.getUsername()));//不会出错

    }

     private static User getUser() {
        User user = new User("张三","12");
        return user;
    }
}    

3. Optional.empty()

​ 如果一个方法的返回值类型是Optional类型。而如果我们经判断发现某次计算得到的返回值为null,这个时候就需要把null封装成Optional对象返回。这时则可以使用Optional静态方法empty来进行封装。

代码演示

public class Demo7 {
    public static void main(String[] args) {
        Optional<User> user = getUser();
        user.ifPresent(user2-> System.out.println(user2.getUsername()));
        Optional<Object> empty = Optional.empty();
        System.out.println();

    }

   private static Optional<User> getUser() {
       User user = new User("张三","12");
       //返回的类型为Optional<User>,返回之前是无法保证这个对象一定是非空,所以当可能是null时,我们
       //返回一个Optional.empty()
       return user==null?Optional.empty(): Optional.of(user);
   }
}

调试结果

在这里插入图片描述

Optional.empty()会返回一个value为null的 Optional。我们使用构造Optional对象时,传入不为null的对象时,该对象存储在Optional中的value中。

常用方法介绍

1. ifPresent

我们获取到一个Optional对象后肯定需要对其中的数据进行使用。这时候我们可以使用其ifPresent方法对来消费其中的值。这个方法会判断其内封装的数据是否为空,不为空时才会执行具体的消费代码。这样使用起来就更加安全了。

示例代码

public class Demo7 {
    public static void main(String[] args) {
        User user = new User("张三","12");
        Optional<User> user1 = Optional.ofNullable(user);
        user1.ifPresent(user2-> System.out.println(user));
        User user2 = null;
        Optional<User> user3 = Optional.ofNullable(user2);
        user3.ifPresent(user4-> System.out.println(user));//啥也不干
    }
}

2. orElse

如果 Optional 中有值则将其返回,否则返回 orElse 方法传入的参数。但是无论 Optional 是否包含值,orElse 方法的参数都会被求值,也就是说,无论如何都会执行默认值的生成。

示例代码

public class Demo7 {
    public static void main(String[] args) {
        User user = new User("张三","12");
        Optional<User> user1 = Optional.ofNullable(user);
        Optional<User> empty = Optional.empty();
        User user2 = user1.orElse(new User("default","default"));
        User user3 = empty.orElse(new User("NULL","NULL"));
        System.out.println(user2);
        System.out.println(user3);

    }
}    

运行结果:
在这里插入图片描述

3. orElseGet

类似于orElse,不同的是只有在 Optional不包含值时,才会调用该函数来生成默认值。这可以提高性能,因为默认值的生成只在需要时才会发生。

示例代码

public class Demo7 {
    public static void main(String[] args) {
        User user = null;
        Optional<User> user1 = Optional.ofNullable(user);
        User user2 = user1.orElseGet(() -> new User("dufault", "default"));
        System.out.println(user2);
    }
}    

4. orElseThrow

获取数据,如果数据不为空就能获取到该数据。如果为空则根据你传入的参数来创建异常抛出。

示例代码

public class Demo7 {
    public static void main(String[] args) {
        User user = new User("张三","12");
        Optional<User> user1 = Optional.ofNullable(user);
       try {
           User user3 = user1.orElseThrow((Supplier<Throwable>) () -> new RuntimeException("user为空"));
           System.out.println(user3);
       } catch (Throwable e) {
           throw new RuntimeException(e);
       }
    }
 }   

5. isPresent

​ 我们可以使用isPresent方法进行是否存在数据的判断。如果为空返回值为false,如果不为空,返回值为true。但是这种方式并不能体现Optional的好处,更推荐使用ifPresent方法

示例代码

public class Demo7 {
    public static void main(String[] args) {
        User user = new User("张三","12");
        Optional<User> user1 = Optional.ofNullable(user);
        if (user1.isPresent()) {
            System.out.println("user不为null");
        }else {
            System.out.println("user为null");
        }
    }
}    

6. map

​ Optional还提供了map可以让我们的对数据进行转换,并且转换得到的数据也还是被Optional包装好的,保证了我们的使用安全。

示例代码

public class Demo7 {
    public static void main(String[] args) {
        User user = new User("张三","12");
        Optional<User> user1 = Optional.ofNullable(user);
        Optional<String> s = user1.map(user2 -> user2.getUsername());
        s.ifPresent(s2-> System.out.println(s2));
    }
}    

各位看官如果觉得文章写得不错,点赞评论关注走一波!谢谢啦!。

在这里插入图片描述

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

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

相关文章

2023/8/11题解

时间限制: 1000MS 内存限制: 65536KB 解题思路 建树 模拟 &#xff0c;复杂在于建树&#xff0c;此处从题目需求可知需要按层建树&#xff0c;所以需要队列模拟&#xff0c;查找比较容易就是普通的深搜 参考代码 #include<bits/stdc.h> using namespace std; vector<…

【自用】云服务器 使用 docker 搭建 HomeAssistant + MQTT 物联网平台

总览 1.搭建流程概述 2.准备工作 3.开始搭建&#xff01; 4.总结 如果想看 ESP32 或其他使用 MicroPython 编程的单片机如何连接到该云服务器&#xff0c;实现 HomeAssistant 控制 单片机的内容&#xff0c;请看我这篇博客的下一篇。 一、搭建流程概述 0.总体流程 我们需要…

Excel小技巧揭秘:结合3行Bat代码,轻松提升工作效率

在日常工作中&#xff0c;Excel是一个不可或缺的工具&#xff0c;而掌握一些小技巧可以大大提升我们的工作效率。今天&#xff0c;我们将介绍一种巧妙的方法&#xff0c;结合仅有3行Bat代码&#xff0c;让你在Excel中实现更多的功能&#xff0c;让同事们都会对你赞叹不已&#…

宋浩高等数学笔记(十一)曲线积分与曲面积分

个人认为同济高数乃至数学一中最烧脑的一章。。。重点在于计算方式的掌握&#xff0c;如果理解不了可以暂时不强求&#xff0c;背熟积分公式即可。此外本贴暂时忽略两类曲面积分之间的联系&#xff0c;以及高斯公式的相关内容&#xff0c;日后会尽快更新&#xff0c;争取高效率…

QGraphicsView实现简易地图4『局部加载-地图漫游』

前文链接&#xff1a;QGraphicsView实现简易地图3『局部加载-地图缩放』 当鼠标拖动地图移动时&#xff0c;需要实时增补和删减瓦片地图&#xff0c;大致思路是计算地图从各方向移动时进出视口的瓦片坐标值&#xff0c;根据变化后的瓦片坐标值来增减地图瓦片&#xff0c;以下将…

c51单片机串行通信示例代码(单片机--单片机通信)(附带proteus线路图)

//这个发送端代码 #include "reg51.h" #include "myheader.h" #define uchar unsigned char long int sleep_i0; long int main_i0; void main() {uchar sendx[6]{2,0,2,3,8,1};sleep(2000);TMOD0x20;TH10XF4;//根据波特率计算公式这里需要设置为这么多才能…

微服务系列(2)--注册中心

在博文&#xff1a;微服务系列(1)里我们提到过注册中心的概念&#xff0c;简单来说微服务注册中心是一个用于存储和管理微服务实例信息的组件&#xff0c;它提供了服务注册、服务发现、服务健康检查等功能&#xff0c;以确保微服务之间的稳定通信。在微服务架构中&#xff0c;各…

火爆全网,Jmeter接口自动化-参数化CSV实战详解(超级详细)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 一般来说&#xf…

MachineLearningWu_16/P72-P77_Diagnostic

x.1 导数&#xff0c;计算图&#xff0c;大型网络 计算图就是根据链式法则求取偏导&#xff0c;大型网络就是多层网络堆叠而成。 x.2 Diagnostic 在我们对深度学习有了一些认知后&#xff0c;最重要的就是模型的诊断&#xff0c;以带有L1正则化的线性回归为例&#xff0c;我…

【Linux】系统内核中System.map中字段含义解释

可以通过命令行过来初始化内容 cat System.map-4.18.0-193.el8.x86_64 | grep pci | grep initcall "T"&#xff1a;表示该符号是一个全局函数&#xff0c;可以被其他模块或文件访问。 "D"&#xff1a;表示该符号是一个全局数据对象&#xff0c;可以被其…

玩转轻叶H5:批量功能上线,落地页创建更高效

在营销领域&#xff0c;落地页作为营销过程的最后一环&#xff0c;不仅要准确传达产品或服务的独特卖点&#xff0c;也要提升互动的友好度&#xff0c;完成承接用户和转化用户的价值作用。 为了满足营销人员的落地页自建需求&#xff0c;我们推出了轻叶H5制作工具&#xff0c;帮…

CVPR 2023 | 4D雷达场景流的跨模态监督学习

注1:本文系“计算成像最新论文速览”系列之一,致力于简洁清晰地介绍、解读非视距成像领域最新的顶会/顶刊论文(包括但不限于 Nature/Science及其子刊; CVPR, ICCV, ECCV, SIGGRAPH, TPAMI; Light‐Science & Applications, Optica 等)。 本次介绍的论文是:CVPR 2023 | 4D雷…

请求转发和请求重定向

目录 1. 定义层面 2. 请求方层面 3. 数据共享层面 4. 最终 url 层面 5. 代码实现层面 请求转发 请求重定向 在Java中&#xff0c;跳转网页的方式有两种&#xff0c;一种是请求转发&#xff0c;另一种是请求重定向&#xff0c;而实际上&#xff0c;这两种方式是有着明显…

最小生成树——prim算法

prim算法详解 prim算法简介prim算法步骤prim复杂度prim样例题目公路修建题目描述输入格式输出格式样例样例输入样例输出 提示 prim样例代码 prim算法简介 P r i m Prim Prim算法是一种用于解决最小生成树问题的贪心算法。最小生成树是一个连通图的生成树&#xff0c;它的所有边…

Vue+SpringBoot项目开发:登录页面美化,登录功能实现(三)

写在开始:一个搬砖程序员的随缘记录上一章写了从零开始VueSpringBoot后台管理系统&#xff1a;Vue3TypeScript项目搭建 VueTypeScript的前端项目已经搭建完成了 这一章的内容是引入element-plus和axios实现页面的布局和前后端数据的串联&#xff0c;实现一个登陆的功能&#x…

LVGL学习笔记 28 - 键盘keyboard

目录 1. 设置关联文本框 2. 设置模式 2.1 LV_KEYBOARD_MODE_TEXT_LOWER 2.2 LV_KEYBOARD_MODE_TEXT_UPPER 2.3 LV_KEYBOARD_MODE_SPECIAL 2.4 LV_KEYBOARD_MODE_NUMBER 2.5 LV_KEYBOARD_MODE_USER_1 ~ LV_KEYBOARD_MODE_USER_4 3. 使能弹窗模式 4. 更改按键布局 5. 事…

uniapp----分包

系列文章目录 uniapp-----封装接口 uniapp-----分包 目录 系列文章目录 uniapp-----封装接口 uniapp-----分包 前言 二、使用步骤 1.创建文件 ​编辑 2.min.js的修改 2.1 subPackages 代码如下&#xff08;示例&#xff09;&#xff1a; 2.2 preloadRule 代码如下&am…

第一次PR经历

第一次PR测试地址&#xff1a;https://github.com/firstcontributions/first-contributions说明文档&#xff1a; https://github.com/firstcontributions/first-contributions/blob/main/translations/README.zh-cn.md

SAP MM学习笔记17-在库品目评价中的标准原价 S 和移动平均价格 V

SAP中有2种价格&#xff0c;标准原价 S 和 移动平均价格 V。 1&#xff0c;标准原价 S 2&#xff0c;移动平均价格 V 在MM03 会计1 Tab中&#xff0c;现行评价区域中&#xff0c;有原价管理区分。 比如下面这个物料 100-100&#xff0c; 它的原价管理区分是 S。 它的合计额…

在Vue中动态引入图片为什么要用require

静态资源和动态资源 静态资源 动态的添加src 动态资源 我们通过网络请求从后端获取的资源 动态的添加src会被当成静态资源 动态的添加src最终会被打包成&#xff1a; 动态的添加图片最会会被编译成一个静态的字符串&#xff0c;然后再浏览器运行中会去项目中查找这个资源…