一文让你理解 Lambda 表达式( 二 )


第二步简化 - 用Iterable.forEach()取代foreach loop:

一文让你理解 Lambda 表达式

文章插图
 
由于静态函数其实只是对List进行了一通操作,这里我们可以甩掉静态函数,直接使用stream()特性来完成 。stream()的几个方法都是接受Predicate<T>,Consumer<T>等参数的(java.util.stream (Java Platform SE 8 )) 。你理解了上面的内容,stream()这里就非常好理解了,并不需要多做解释 。
第三步简化 - 利用stream()替代静态函数:
一文让你理解 Lambda 表达式

文章插图
 
对比最开始的Lambda写法,这里已经非常非常简洁了 。但是如果,我们要求变一下,变成print这个人的全部信息,及p -> System.out.println(p); 那么还可以利用Method reference来继续简化 。所谓Method reference, 就是用已经写好的别的Object/Class的method来代替Lambda expression 。格式如下:
一文让你理解 Lambda 表达式

文章插图
 
第四步简化 - 如果是println(p),则可以利用Method reference代替forEach中的Lambda表达式:
一文让你理解 Lambda 表达式

文章插图
 
这基本上就是能写的最简洁的版本了 。
例二:
Lambda配合Optional<T>可以使Java对于null的处理变的异常优雅
这里假设我们有一个person object,以及一个person object的Optional wrApper:
一文让你理解 Lambda 表达式

文章插图
 
Optional<T>如果不结合Lambda使用的话,并不能使原来繁琐的null check变的简单 。
一文让你理解 Lambda 表达式

文章插图
 
只有当Optional<T>结合Lambda一起使用的时候,才能发挥出其真正的威力!
我们现在就来对比一下下面四种常见的null处理中,Java 8的Lambda+Optional<T>和传统Java两者之间对于null的处理差异 。
情况一 - 存在则开干
一文让你理解 Lambda 表达式

文章插图
 
情况二 - 存在则返回,无则返回屁
一文让你理解 Lambda 表达式

文章插图
 
情况三 - 存在则返回,无则由函数产生
一文让你理解 Lambda 表达式

文章插图
 
情况四 - 夺命连环null检查
一文让你理解 Lambda 表达式

文章插图
 
由上述四种情况可以清楚地看到,Optional<T>+Lambda可以让我们少写很多ifElse块 。尤其是对于情况四那种夺命连环null检查,传统java的写法显得冗长难懂,而新的Optional<T>+Lambda则清新脱俗,清楚简洁 。




推荐阅读