static Stream> zip(Stream
{
Iterator i=as.iterator();
return bs.filter(x->i.hasNext()).map(b->new Pair<>(i.next(), b));
}
这不提供并行执行,但也没有提供原始的zip实现.
而作为F. Böller has pointed out它不起作用,如果bs是无限的,而不是.对于适用于无限和有限流的所有可能组合的解决方案,中间迭代器检查hasNext方法中的两个源似乎是不可避免的:
static Stream> zip(Stream
Iterator i1 = as.iterator();
Iterator i2 = bs.iterator();
Iterable> i=()->new Iterator>() {
public boolean hasNext() {
return i1.hasNext() && i2.hasNext();
}
public Pair next() {
return new Pair(i1.next(), i2.next());
}
};
return StreamSupport.stream(i.spliterator(), false);
}
如果你想要平行的压缩,你应该考虑流的来源.例如.您可以压缩两个ArrayLists(或任何RandomAccessList)
ArrayList l1=new ArrayList<>();
ArrayList l2=new ArrayList<>();
IntStream.range(0, Math.min(l1.size(), l2.size()))
.mapToObj(i->new Pair(l1.get(i), l2.get(i)))
. …
¹(除非您直接实现了Spliterator)