更加优雅的判断对象是否为空

不管现实多么惨不忍睹,都要持之以恒地相信,这只是黎明前短暂的黑暗而已。不要惶恐眼前的难关迈不过去,不要担心此刻的付出没有回报,别再花时间等待天降好运。真诚做人,努力做事!你想要的,岁月都会给你。更加优雅的判断对象是否为空,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

我们在日常的编码中,会有很多实体类里面再嵌套实体类,实体里面还嵌套实体的情况。

那么我们在取出最里面的实体的某个值的时候,我们就不得不一层层get这个让人蛋疼的实体,一层层的做判断。

举例说明:

有一个学校详情信息实体类 SchoolInfoDto ,里面包含 学生详情信息类 StudentInfoDto 和 教师详情信息类 TeacherInfoDto。

而教师详情信息类里又包含 教师课程信息类 TeacherCourseDto等。如下图:

更加优雅的判断对象是否为空

更加优雅的判断对象是否为空

更加优雅的判断对象是否为空

更加优雅的判断对象是否为空

现有个需求:

        查出光明一中 小王老师 负责哪些班级的课程?如果没有,返回 ‘无’。

按照平常我们多半会写if 判空处理:

更加优雅的判断对象是否为空

看看这一层层的非空校验,是不是很难受。

Java 8引入了新方法(Optional

  • Optional.of(T value)

该方法通过一个非 null 的 value 来构造一个 Optional,返回的 Optional 包含了 value 这个值。对于该方法,传入的参数一定不能为 null,否则便会抛出 NullPointerException。

//of(T value)
Optional<String> str = Optional.of("");
//传入参数为null,抛出NullPointerException.
Optional<String> strNull = Optional.of(null);
  • Optional.ofNullable(T value)

Optional.ofNullable(T value):若 value 不为 null,创建 Optional 实例,否则创建空实例
该方法和 of 方法的区别在于,传入的参数可以为 null

public static <T> Optional<T> ofNullable(T value) {
	//进行三目运算,判断传入的参数是否为 null,如果为 null 的话,返回的就是 Optional.empty()。
    return value == null ? empty() : of(value);
}


Optional<String> nullableOpt = Optional.ofNullable(str);
  • Optional.empty()

该方法用来构造一个空的 Optional,即该 Optional 中不包含值 —— 其实底层实现还是 如果 Optional 中的 value 为 null 则该 Optional 为不包含值的状态,然后在 API 层面将 Optional 表现的不能包含 null 值,使得 Optional 只存在 包含值 和 不包含值 两种状态。

//empty() :用于创建一个没有值的Optional对象:
Optional<String> emptyOpt = Optional.empty();

优化后的写法:

        SchoolInfoDto schoolInfo = this.queryTeacherCourse(schoolName, teacherPhone);
        String grade = Optional.of(schoolInfo).map(SchoolInfoDto::getTeacherInfoDto)
                .map(TeacherInfoDto::getTeacherCourseDto)
                .map(TeacherCourseDto::getGrade).orElse("无");
        System.out.println("最终结果:" + grade);

扩展:

使用orElse方法设置默认值,Optional类还包含其他方法用于获取值:
1.orElse():如果有值就返回,否则返回一个给定的值作为默认值;
2.orElseGet():与orElse()方法作用类似,区别在于生成默认值的方式不同。该方法接受一个3.Supplier<? extends T>函数式接口参数,用于生成默认值;
4.orElseThrow():与前面介绍的get()方法类似,当值为null时调用这两个方法都会抛出NullPointerException异常,区别在于该方法可以指定抛出的异常类型。
 

如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、评论、收藏➕关注,您的支持是我坚持写作最大的动力。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/161435.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!