我们在日常的编码中,会有很多实体类里面再嵌套实体类,实体里面还嵌套实体的情况。
那么我们在取出最里面的实体的某个值的时候,我们就不得不一层层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