第二步简化 - 用Iterable.forEach()取代foreach loop:
文章插图
由于静态函数其实只是对List进行了一通操作,这里我们可以甩掉静态函数,直接使用stream()特性来完成 。stream()的几个方法都是接受Predicate<T>,Consumer<T>等参数的(java.util.stream (Java Platform SE 8 )) 。你理解了上面的内容,stream()这里就非常好理解了,并不需要多做解释 。
第三步简化 - 利用stream()替代静态函数:
文章插图
对比最开始的Lambda写法,这里已经非常非常简洁了 。但是如果,我们要求变一下,变成print这个人的全部信息,及p -> System.out.println(p); 那么还可以利用Method reference来继续简化 。所谓Method reference, 就是用已经写好的别的Object/Class的method来代替Lambda expression 。格式如下:
文章插图
第四步简化 - 如果是println(p),则可以利用Method reference代替forEach中的Lambda表达式:
文章插图
这基本上就是能写的最简洁的版本了 。
例二:
Lambda配合Optional<T>可以使Java对于null的处理变的异常优雅
这里假设我们有一个person object,以及一个person object的Optional wrApper:
文章插图
Optional<T>如果不结合Lambda使用的话,并不能使原来繁琐的null check变的简单 。
文章插图
只有当Optional<T>结合Lambda一起使用的时候,才能发挥出其真正的威力!
我们现在就来对比一下下面四种常见的null处理中,Java 8的Lambda+Optional<T>和传统Java两者之间对于null的处理差异 。
情况一 - 存在则开干
文章插图
情况二 - 存在则返回,无则返回屁
文章插图
情况三 - 存在则返回,无则由函数产生
文章插图
情况四 - 夺命连环null检查
文章插图
由上述四种情况可以清楚地看到,Optional<T>+Lambda可以让我们少写很多ifElse块 。尤其是对于情况四那种夺命连环null检查,传统java的写法显得冗长难懂,而新的Optional<T>+Lambda则清新脱俗,清楚简洁 。
推荐阅读
- 三种方法让你对窑温程度了如指掌
- 10分钟彻底理解Redis持久化和主从复制
- 让你尽兴品茶的百样优雅茶具
- 一文看懂房贷利率要不要转成LPR?
- Redmi|1699元起!Redmi Note 11 Pro/Pro+官方降价:一文看懂买哪款
- 新版微信的隐藏彩蛋,可以让你轻松「拍」遍好友
- 还有这样的神奇软件!让你用PC操控手机的神器
- 一文带你了解爬虫
- 深入理解C语言的指针
- 初学跑步如何循序渐进?3个步骤让你爱上跑步