多平台统一管理软件接口,如何实现多平台统一管理软件接口
400
2023-02-09
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
Stream
数组转stream
对于数组,Arrays提供了stream()方法。
String[] arr = new String[]{"a", "b", "c"};
Stream
Map转stream
Map并不是一个序列,不是集合,没办法直接转成stream(). 但entrySet()是Set,可以转
Map
Stream
直接创建Stream
Stream也提供了API直接生成一个Stream,这个Stream大概可以理解成一个List。因为内部就是数组实现的。
Stream
读取文件的Stream
用过linux的就会对其命令行的管道符敬佩不已,一个管道符就可以源源不断的做处理。在Java里读取文件也可以实现类似的功能。
long uniqueWords = 0;
try (Stream
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);
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~