1、Java 8 Stream
Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据 , Stream 使用一种类似用 SQL 语句从数据库查询数据的直观方式来提供一种对 Java 集合运算和表达的高阶抽象。
这种风格将要处理的元素集合看作一种流, 流在管道中传输, 并且可以在管道的节点上进行处理, 比如筛选, 排序,聚合等
2、流是什么
Stream(流)是一个来自数据源的元素队列并支持聚合操作
- 数据源 流的来源: 可以是集合,数组,I/O channel, 产生器generator 等
-聚合操作: 类似SQL语句一样的操作, 比如filter, map, reduce, find, match, sorted等。
和以前的Collection操作不同, Stream操作还有两个基础的特征。
*两个特征:*
-Pipelining: 中间操作都会返回流对象本身。 这样多个操作可以串联成一个管道, 如同流式风格(fluent style)。 这样做可以对操作进行优化, 比如延迟执行(laziness)和短路( short-circuiting)。
-内部迭代: 以前对集合遍历都是通过Iterator或者For-Each的方式, 显式的在集合外部进行迭代, 这叫做外部迭代。 Stream提供了内部迭代的方式, 通过访问者模式(Visitor)实现。
3、生成流
stream() − 为集合创建串行流。
parallelStream() − 为集合创建并行流。
4、 stream()
> *filter:* 对于Stream中包含的元素使用给定的过滤函数进行过滤操作,新生成的Stream只包含符合条件的元素;
代码片段
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
/**
* 通过流过滤数组中不为空的字符串
*/
// List<String> 转为流Stream<String>
Stream<String> stringsStream = strings.stream();
// 调用filter 过滤不为空的
stringsStream = stringsStream.filter(string -> !string.isEmpty());
//collect()方法的参数则被用来指定如何进行聚集操作。在这里我们使用toList()以把元素输出到List中
strings = stringsStream.collect(Collectors.toList());
System.out.println("输出不为空的字符串=" + strings.toString());
> map
map 方法用于映射每个元素到对应的结果,
distinct: 对于Stream中包含的元素进行去重操作(去重逻辑依赖元素的equals方法),新生成的Stream中没有重复的元素;
代码片段:
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
stringsStream = strings.stream();
stringsStream = stringsStream.filter(string -> !string.isEmpty());
stringsStream =stringsStream.map(string->string.toUpperCase());
stringsStream.distinct();
forEach
Stream 提供了新的方法 ‘forEach’ 来迭代流中的每个数据
代码片段
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
stringsStream = strings.stream();
stringsStream = stringsStream.filter(string -> !string.isEmpty());
System.out.println("转成大写后的字符串:");
stringsStream.forEach(action->{
action =action.toUpperCase();
System.out.println(" "+action);
});
limit
对一个Stream进行截断操作,获取其前N个元素,如果原Stream中包含的元素个数小于N,那就获取其所有的元素;
代码片段
strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
stringsStream = strings.stream();
stringsStream = stringsStream.limit(3);
strings = stringsStream.collect(Collectors.toList());
flatMap
flatMap 把 Stream 中的层级结构扁平化,就是将最底层元素抽出来放到一起,最终输出的新 Stream , 就是把 将小流合并成一个大流
{{1,2},{3,4},{5,6}} - > flatMap - > {1,2,3,4,5,6}