Stream无限流
对于Stream流,有几点需要注意,首先不会自己存储元素,并且不会改变源对象,而是每次都返回一个持有结果的新的Stream,再者,只有终止操作触发,才会进行处理,称为惰性求值。
对于无限流,jdk8提供了两种函数生成方式。
第一种是Steam类中静态的iterate()方法,该方法需要传入两个参数,一个作为seed,即种子,另外一个是一个T apply(T) 的一个函数。而所谓的无限流,每次都会进行迭代,并调用apply方法更新流的元素并且返回一个新的流,如果不使用中间操作进行限制,在终止操作触发时则会无限执行。
第二种是Stream的静态的generate方法,generate方法返回一个无限连续的流,该方法需要传入一个供给型函数接口实现参数,每个元素由提供的供应商(Supplier接口)生成。,这种生成无限流的方式,可以用来造大量数据。
造数据Demo:
public class Person {
private int age;
public Person(int age) {
this.age = age;
}
public static Person genAge(){
return new Person(new Random().nextInt(100));
}
@Override
public String toString() {
return "Person{" +
"age=" + age +
'}';
}
}
public class Demo{
public static void main(String[] args) {
IntStream.iterate(0, t -> ++t > 9 ? 0 : t).limit(19).forEach(System.out::println);// 循环0到9
// 自定义类型
Stream.generate(Person::genAge).limit(500).forEach(System.out::println);
}
}