Java8如何构建一个Stream示例详解
stream初体验
stream是java8中操作集合的一个重要特性,我们先来看看java里面是怎么定义stream的:
"a sequence of elements supporting sequential and parallel aggregate operations."
我们来解读一下上面的那句话:
1、stream是元素的集合,这点让stream看起来用些类似iterator;
2、可以支持顺序和并行的对原stream进行汇聚的操作。
stream的创建方式有很多种,除了最常见的集合创建,还有其他几种方式。
list转stream
list继承自collection接口,而collection提供了stream()方法。
list<integer> list = lists.newarraylist(1, 2, 3); stream<integer> stream = list.stream();
数组转stream
对于数组,arrays提供了stream()方法。
string[] arr = new string[]{"a", "b", "c"}; stream<string> stream = arrays.stream(arr);
map转stream
map并不是一个序列,不是集合,没办法直接转成stream(). 但entryset()是set,可以转
map<string, object> map = maps.newhashmap(); stream<entry<string, object>> stream = map.entryset().stream();
直接创建stream
stream也提供了api直接生成一个stream,这个stream大概可以理解成一个list。因为内部就是数组实现的。
stream<integer> integerstream = stream.of(1, 2, 3);
读取文件的stream
用过linux的就会对其命令行的管道符敬佩不已,一个管道符就可以源源不断的做处理。在java里读取文件也可以实现类似的功能。
long uniquewords = 0; try (stream<string> lines = files.lines(paths.get("data.txt"), charset.defaultcharset())) { uniquewords = lines.flatmap(l -> arrays.stream(l.split(" "))) .distinct() .count(); } catch (ioexception e) { // }
通过函数来生成无限流
stream提供了iterate来生成一个无限序列,一个基于初始值的无限序列。可以用lambda设置序列的生成规则,比如每次增加2.
stream.iterate(0, n -> n + 2) .limit(10) .foreach(system.out::println);
再比如,斐波那契数列(fibonacci sequence)
stream.iterate(new int[]{0, 1}, t -> new int[]{t[1], t[0] + t[1]}) .limit(20) .map(t -> t[0]) .foreach(system.out::println);
stream还提供了另一个generate方法来生成序列。接收一个用户指定的生成序列函数intsupplier.
intsupplier fib = new intsupplier() { private int previous = 0; private int current = 1; @override public int getasint() { int oldprevious = this.previous; int nextvalue = this.previous + this.current; this.previous = this.current; this.current = nextvalue; return oldprevious; } }; intstream.generate(fib).limit(10).foreach(system.out::println);
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。