- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
在官方文档中你可以看到:
UNORDERED
Indicates that the collection operation does not commit to preserving the encounter order of input elements.
如果没有任何示例,这不是很有帮助。
我的问题是,UNORDERED
特征到底是什么意思?我应该将它与 min 或 sum 等缩减收集器一起使用,还是仅适用于集合收集器?
在 OpenJDK 中,减少操作(min、sum、avg)看起来具有空特征。我希望在那里至少找到 CONCURRENT
和 UNORDERED
。
最佳答案
在没有特殊请求的情况下,流操作必须表现得好像元素是按照源的遇到顺序处理的。对于某些操作——例如使用关联操作进行归约——可以遵守此约束并仍然获得高效的并行执行。但是,对于其他人来说,这种限制非常有限。而且,对于某些问题,此约束对用户没有意义。考虑以下流管道:
people.stream()
.collect(groupingBy(Person::getLastName,
mapping(Person::getFirstName));
与“Smith”关联的名字列表按照它们在初始流中出现的顺序出现在 map 中是否重要?对于一些问题,是的,对于一些不是——我们不希望流库为我们猜测。无序收集器表示可以按照与 Smith 姓氏在输入源中出现的顺序不一致的顺序将名字插入列表。通过放宽此约束,有时(并非总是),流库可以提供更高效的执行。
例如,如果你不关心这个订单保存,你可以执行它:
people.parallelStream()
.collect(groupingByConcurrent(Person::getLastName,
mapping(Person::getFirstName));
并发收集器是无序的,这允许优化共享底层 ConcurrentMap
,而不是具有 O(log n)
映射合并步骤。放宽排序约束会带来真正的算法优势——但我们不能假设约束无关紧要,我们需要用户告诉我们这一点。使用 UNORDERED
收集器是告诉流库这些优化是公平游戏的一种方式。
关于java - Java 8 Collector UNORDERED 特性是什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39942054/
以下面的列表为例: List input = List.of("FOO", "FOO", "FOO", "FOO", "FOO", "BAR", "BAR", "BAZ", "BAZ", "BAZ",
我有一个类似于下面的类 MyObject . public class MyObject { private String key; // not unique. multiple objec
我想获取按频率键控的数组值频率图。我能够得到相反的 - 按值键控的 map 。尝试切换参数,但 grouping by 不接受 Collector 作为第一个参数。 另一个问题,如何将 Map 实现更
我是 Java 8 Stream API 的新手,但我想用它来解决以下问题。假设我有一个名为 InputRecord 的 POJO,其中包含 name、fieldA 和 fieldB 属性,这些属性可
基准测试在 intel core i5, Ubuntu 下运行 java version "1.8.0_144" Java(TM) SE Runtime Environment (build 1.8.
我尝试使用流和收集器对值进行分组。我有我必须拆分的字符串列表。 我的数据: List stringList = new ArrayList<>(); stringList.add("Key:1,2,3
我想创建一个 Map来自 List的 Points并在映射中使用相同的 parentId 映射列表中的所有条目,例如 Map> . 我用了Collectors.toMap()但它没有编译: Map>
我已经实现了以下示例: Map> map = events.getItems().stream() .collect(Collectors.groupingBy(Event::getS
这个问题在这里已经有了答案: java 8 Collector is not a functional interface, who can tell why? (2 个回答) Java8: Usin
我想通过 Java 8 Stream 和 Collector 接口(interface)将 Map 转换为 ConcurrentHashMap,然后是我可以使用的两个选项。 第一个: Map mb =
如果我有一个对象列表(~200 个元素),只有几个唯一对象(~20 个元素)。 我只想拥有独特的值(value)。之间list.stream().collect(Collectors.toSet())
对于下面开发的 Java 8 代码,我收到以下错误。在此示例中,尝试将 Dish Name 的所有名称连接到一个变量中。使用下面的代码我得到了这个 "The method collect(Collec
我正在尝试使用rook在kubernetes集群上配置ceph,我已经运行了以下命令: kubectl apply -f common.yaml kubectl apply -f operator.y
这是我的流: Stream> futureStream = IntStream .iterate(1, n -> n n++) .mapToObj(pageNumber -> thi
Collector.of(Supplier 供应商、BiConsumer 累加器、BinaryOperator 组合器、Function 完成器、Characterstics...) Coll
按照常规思维,往一个map里put一个已经存在的key,会把原有的key对应的value值覆盖,然而通过一次线上问题,发现Java8中的Collectors.toMap反其道而行之,它默认给抛异常,
我想通过基于 LocalDateTime 的集合进行分组,但我只想获取小时,而不是分钟、秒... .collect(Collectors.groupingBy(cp -> getUpdateLocal
这个问题在这里已经有了答案: What is the point of "final class" in Java? (24 个答案) 关闭 3 年前。 为什么 Collectors 类在 Java
我有一个College具有嵌套静态类的类 Dept 学院 class College { private String collegeName; private Dept dept; public D
在Java库源代码中,Collectors#toList方法的定义如下: public static Collector> toList() { return new CollectorIm
我是一名优秀的程序员,十分优秀!