package jdk180reduce;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Optional; import test.Teacher;
import test.User; public class optional { /**
* 1.Optional的用法,可以,用了reduce计算,也可以不判断非null
* 2.三个方法:Optional.empty(), Optional.of, Optional.ofNullable
* 3.orElse()用法
* 4.ifPresent()区别isPresent()
* 5.orElse和orElseGet()不同*/
public static void main(String[] args) { emptyOptional();
orelse();
orelseDifferent();
whenMap_thenOk(); List<Student> stuList = new ArrayList<>(4);
stuList.add(new Student("刘一", 59));
stuList.add(new Student("陈二", 58));
stuList.add(new Student("张三", 98));
stuList.add(new Student("吴九", 100)); //计算分数在60分一下的分数总和 注意:以前没有60分以下的,不加判断就会出现空指针异常: score.orElse(0)= 有值取值,无值为0
Optional<Integer> score = stuList.stream().map(Student :: getScore).filter(s -> s<60).reduce((a,b) -> a+b);
System.out.println("score="+score.orElse(0)); // Map<Integer,String> map = new HashMap<>();
map.put(20180001,"章子");
map.put(20180002,"小米");
map.put(20180003,"大黄"); String name = Optional.ofNullable(map.get(20180001)).orElse("无");
System.out.println(name); //无 } public static void emptyOptional() {
// 以下会导致空指针:No value present
// Optional<User> emptyOpt = Optional.empty();
// emptyOpt.get(); //当用.of的时候必须不为null,否则也会报空指针
User user = new User();
Optional<User> opt = Optional.of(user);
opt.get(); //如果不确定传入的值是否为null,用ofNullable
Object opf = Optional.ofNullable(null).orElse("null");
System.out.println(opf); //ofNullable方法也要isPresent判断是否有值,或者用.orElse赋值
String name = "John";
Optional<String> opu = Optional.ofNullable(null);
if (opu.isPresent()) {
System.out.println(opu.get());
} else {
System.out.println("opu无值");
} //ifPresent区别isPresent,是用labam表达式
Optional<String> opp = Optional.ofNullable(name);
opp.ifPresent(it -> System.out.println(opp.get()));
} public static void orelse() { //orElse:如果有值则返回该值user,否则返回传递给它的参数值user2:
User user = null;
User user2 = new User();
user2.setUserId(2);
User result = Optional.ofNullable(user).orElse(user2);
System.out.println("result="+result);
} /**
* orElse和orElseGet()不同
*/
public static void orelseDifferent() { User user = null;
System.out.println("1----Using orElse");
User result = Optional.ofNullable(user).orElse(createNewUser());
System.out.println("1----Using orElseGet");
User result2 = Optional.ofNullable(user).orElseGet(() -> createNewUser()); User user4 = new User();
user4.setAge(2);
System.out.println("2----Using orElse");
User result4 = Optional.ofNullable(user4).orElse(createNewUser());
System.out.println("result4====="+result4); System.out.println("2----Using orElseGet");
User result3 = Optional.ofNullable(user4).orElseGet(() -> createNewUser());
System.out.println("result3===="+result3); //结论:两个 Optional对象都包含非空值,两个方法都会返回对应的非空值。
//不过,orElse() 方法仍然创建了 User 对象。 与之相反,orElseGet() 方法不创建 User 对象。
//在执行较密集的调用时,比如调用 Web 服务或数据查询,这个差异会对性能产生重大影响。
} private static User createNewUser() {
System.out.println("Creating New User");
User user = new User();
user.setName("java");
return user;
} public static void whenMap_thenOk() {
User user = createNewUser();
User userNull = new User();
String name = Optional.ofNullable(user).map(u -> u.getName()).orElse("vivi");
Optional<User> result = Optional.ofNullable(user).filter(u -> u.getName() != null && u.getName().contains("li"));
result.ifPresent(u -> {
String myName = result.get().getName();
//-------------
System.out.println("过滤值:" + result.get().getName());
}); //第二种:
if (result.isPresent()) {
System.out.println("过滤值2:" + result.get().getName());
}
} }

java8 Optional 类的更多相关文章

  1. Java8 Optional类

    概述 到目前为止,著名的NullPointerException是导致Java应用程序失败的最常见原因.过去,为了解决空指针异常,Google公司著名的Guava项目引入了Optional类,Guav ...

  2. 详解Java8 Optional类{最全}

    1:Optional 1.1 概述 Optional 类主要解决的问题是臭名昭著的空指针异常(NullPointerException),提供了一些的方法代替过去的if-else处理逻辑,并与Stre ...

  3. Java8 Optional类使用小结

    Optional类的Javadoc描述如下: 这是一个可以为null的容器对象.如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象. of:  为非null的值创建一 ...

  4. Java8 Optional的简单操作

    我们经常会遇到这种情况:首先判断一个对象是否为null,如果不为null,获取一个对象中的一个属性,如果该属性不为null,又获取该属性的属性,如果该属性的属性不为null,又获取属性的属性的属性: ...

  5. 【Todo】Java学习笔记 100==100 & Reflection API & Optional类详解 & DIP、IoC、DI & token/cookie/session管理会话方式

    为什么1000 == 1000返回为False,而100 == 100会返回为True?   Link Java Reflection API:Link Java8 Optional 类深度解析: L ...

  6. Java8之Optional类

    写在前头 今天再看阿里的Java开发手册,里面异常处理第10条提到这样一个建议. [推荐]防止 NPE ,是程序员的基本修养,注意 NPE 产生的场景:1 ) 返回类型为基本数据类型,return 包 ...

  7. java8新特性之Optional类

    NullPointException可以说是所有java程序员都遇到过的一个异常,虽然java从设计之初就力图让程序员脱离指针的苦海,但是指针确实是实际存在的,而java设计者也只能是让指针在java ...

  8. Java8新特性之空指针异常的克星Optional类

    Java8新特性系列我们已经介绍了Stream.Lambda表达式.DateTime日期时间处理,最后以"NullPointerException" 的克星Optional类的讲解 ...

  9. Java8系列 (五) Optional类

    概述 在Java8之前, 如果需要对一个变量做一次 null 检查, 通常会像下面这样写 T t = service1.query(); if (t != null) { K k = service2 ...

随机推荐

  1. 用java方式实现快速排序

    一.基本思想 快速排序采用分治的策略,具体如下:选择一个关键值作为基准值,找到一个元素小于比基准值小的都在左边序列(一般是无序的),比基准值大的都在右边(一般是无序的).一般选用序列第一个元素作为基准 ...

  2. K-means聚类分析

    一.原理 先确定簇的个数,K 假设每个簇都有一个中心点 centroid 将每个样本点划分到距离它最近的中心点所属的簇中 选择K个点做为初始的中心点 while() { 将所有点分配个K个中心点形成K ...

  3. 洞悉MySQL底层架构:游走在缓冲与磁盘之间

    提起MySQL,其实网上已经有一大把教程了,为什么我还要写这篇文章呢,大概是因为网上很多网站都是比较零散,而且描述不够直观,不能系统对MySQL相关知识有一个系统的学习,导致不能形成知识体系.为此我撰 ...

  4. Java实现 蓝桥杯VIP 算法提高 盾神与砝码称重

    算法提高 盾神与砝码称重 时间限制:1.0s 内存限制:256.0MB 提交此题 查看参考代码 问题描述 有一天,他在宿舍里无意中发现了一个天平!这个天平很奇怪,有n个完好的砝码,但是没有游码.盾神为 ...

  5. java实现迷宫走法

    ** 迷宫走法** 迷宫问题 对于走迷宫,人们提出过很多计算机上的解法.深度优先搜索.广度优先搜索是使用最广的方法.生活中,人们更愿意使用"紧贴墙壁,靠右行走"的简单规则. 下面的 ...

  6. git提交拉取远程仓库

    https://gitee.com/ ---- 国内服务器 https:/github.com/ ---- 国外服务器 git init  ---- 初始化(创建主分支)仓库 git clone 拉取 ...

  7. STL关联容器

    这里简单学习一下STL关联容器,主要是map.multimap.set.multiset以及unordered_map.前四个底层实现都是利用红黑树实现的,查找算法时间复杂度为\(O(log(n))\ ...

  8. ROS 机器人技术 - 解决 ROS_INFO 不能正确输出 string 的问题!

    一.输出「??」 项目调试一个节点,打印 ROS 信息时发现设置的节点名称都是问号: ROS_INFO("[%s]: camera_extrinsic_mat", kNodeNam ...

  9. Unable to open debugger port (127.0.0.1:55119): java.net.SocketException "Socket closed"

    1.端口问题 排查端口,lsof -i:8080 修改端口等 2.权限问题 端口排查无解的话,查看idea Event Log(View->Tool Window->Event Log) ...

  10. hadoop知识整理(2)之MapReduce

    之前写的关于MR的文章的前半部分已丢. 所以下面重点从3个部分来谈MR: 1)Job任务执行过程,以及主要进程-ResourceManager和NodeManager作用: 2)shuffle过程: ...