【转载】JDK8 特性 stream(),lambda表达式,

Stream()表达式

  虽然大部分情况下stream是容器调用Collection.stream()方法得到的,但stream和collections有以下不同:

无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java容器或I/O channel等。
为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。

1、forEach() 使用该方法迭代流中的每个数据

2、sorted() 使用该方法排序数据

参考地址:https://blog.csdn.net/kris1025/article/details/85861196

参考地址:https://blog.csdn.net/lsgqjh/article/details/63686383

3、filter():使用该方法过滤

4、limit():使用该方法截断

5、skip():与limit互斥,使用该方法跳过元素

6、distinct():使用该方法去重,注意:必须重写对应泛型的hashCode()和equals()方法

7、max,min,sum,avg,count

8、map():接收一个方法作为参数,该函数会被应用到每个元素上,并将其映射成一个新的元素

9、flatMap():对每个元素执行mapper指定的操作,并用所有mapper返回的Stream中的元素组成一个新的Stream作为最终返回结果,通俗易懂就是将原来的stream中的所有元素都展开组成一个新的stream

10、findFirst() :使用该方法获取第一个元素

11、reduce() :多面手

12、使用collect()做字符串join

参考地址:https://blog.csdn.net/chenhao_c_h/article/details/80691284

Lambda表达式

 
上一篇:JAVA要死了吗?不!我来告诉你为什么!


下一篇:react纯前端不依赖于打包工具的代码