Stream无限流
对于Stream流,有几点需要注意,首先不会自己存储元素,并且不会改变源对象,而是每次都返回一个持有结果的新的Stream,再者,只有终止操作触发,才会进行处理,称为惰性求值。
对于无限流,jdk8提供了两种函数生成方式。
第一种是Steam类中静态的iterate()方法,该方法需要传入两个参数,一个作为seed,即种子,另外一个是一个T apply(T) 的一个函数。而所谓的无限流,每次都会进行迭代,并调用apply方法更新流的元素并且返回一个新的流,如果不使用中间操作进行限制,在终止操作触发时则会无限执行。
第二种是Stream的静态的generate方法,generate方法返回一个无限连续的流,该方法需要传入一个供给型函数接口实现参数,每个元素由提供的供应商(Supplier接口)生成。,这种生成无限流的方式,可以用来造大量数据。
造数据Demo: