首先谈谈Stream的概念以及Java为什么引入Stream
Stream是JAVA8引入的重要特性之一,它是对数据源的一个封装,通过这个封装对象可以对数据源进行处理,Stream本身并不是数据存储容器,跟数据结构也没有直接关系。
为什么要引入Stream呢?没有Stream的JAVA7以及之前的版本,也一样可以处理数据啊?
这里要提到“函数式”编程了,熟悉python和Scala的朋友可能对函数式编程有一定的认知,函数式编程的方式在数据处理上非常的高效,java8 在设计的时候应该是重点考虑了支持函数式编程模式,Stream仅仅是其特性之一,像lamda表达式、函数式接口等特性也都是为函数式编程服务的。
如何构造Stream
1,Stream.of 方法
2,List对象可以直接获取到Stream;如:stringList.stream()
3,Stream.builder().build(); 方式
如何利用stream来高效处理数据
1.数据遍历并处理 forEach方法
String[] strs = {“a”, “b”, “c”, “d”};
Stream stringStream = Stream.of(strs);
stringStream.forEach(s -> System.out.println(s));
2. 数据转换 map方法
面向函数式编程,一般倾向于数据对象是不可变的,当需要改变的时候可以生成新的对象ÿ