作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我使用 Guava 的库 Streams.stream(iterator) 方法将迭代器转换为流。然后我在该流上调用并行并执行一些操作。
我想知道迭代器到流的转换是在共享线程池线程上完成还是事先完成。
Stream<MyItem> myItemStream = Streams.stream(myItemIterator);
myItem.parallel()...
想知道如果迭代器转换是在共享线程池线程上完成的,这会给我的用例带来线程安全方面的问题。
谢谢!
最佳答案
对 Streams.stream(Iterator)
的调用只是围绕调用 java StreamSupport
类的便捷方法:
public static <T> Stream<T> stream(Iterator<T> iterator) {
return StreamSupport.stream(Spliterators.spliteratorUnknownSize(iterator, 0), false);
}
因此 Stream 将使用通用的 ForkJoinPool。
关于java - 将迭代器转换为流并调用并行,转换是否在共享线程池线程上完成?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51445323/
我是一名优秀的程序员,十分优秀!