我了解使用.stream()
,我可以使用类似链操作.filter()
或使用并行流。但是,如果我需要执行小的操作(例如,打印列表的元素),它们之间有什么区别?
collection.stream().forEach(System.out::println);
collection.forEach(System.out::println);
对于诸如所示的简单情况,它们基本上是相同的。但是,有许多细微的差异可能很重要。
一个问题是订购。使用Stream.forEach
,顺序不确定。顺序流不太可能发生,但仍可以按Stream.forEach
任意顺序执行。这确实在并行流中经常发生。相反,如果指定,Iterable.forEach
则总是以的迭代顺序执行Iterable
。
另一个问题是副作用。Stream.forEach
必须指定中的动作为非干扰动作。(请参阅java.util.stream
软件包doc。)Iterable.forEach
可能会有更少的限制。对于中的集合java.util,Iterable.forEach
通常将使用该集合的Iterator
,其中大多数被设计为快速失败的,并且ConcurrentModificationException
如果在迭代过程中对结构进行了修改,则会抛出该集合。但是,在迭代过程中允许进行非结构化的修改。例如,ArrayList类文档说“仅设置元素的值不是结构修改”。因此,针对ArrayList.forEach
允许在底层中设置值ArrayList而不会出现问题。
并发集合又一次不同。它们不是快速失败,而是设计为弱一致性。完整的定义在该链接上。不过,请简要考虑一下ConcurrentLinkedDeque
。传递给其forEach
方法的操作被允许修改底层双端队列,即使在结构上ConcurrentModificationException
也是如此,并且永远不会抛出该异常。但是,发生的修改在此迭代中可能可见,也可能不可见。(因此保持“弱”一致性。)
如果Iterable.forEach
正在同步的集合上进行迭代,则仍然可以看到另一个差异。在这样的集合上,Iterable.forEach
获取一次该集合的锁,并在对action方法的所有调用中保持该锁。该Stream.forEach
调用使用集合的分隔符,该分隔符不会锁定,并且依赖于不干扰的流行规则。支持该流的集合可以在迭代期间进行修改,如果是,则ConcurrentModificationException
可能导致行为不一致或行为不一致。
我理解,使用,我可以使用类似的链操作,或者使用并行流。但是如果我需要执行小操作(例如,打印列表的元素),它们之间有什么区别呢?
这是一个例子:代码A: 另一个代码B可以这样使用: 两者有什么区别,有和没有?
问题内容: 两者都意味着空间,但是有什么区别吗? 问题答案: 一个是不间断空间,另一个是常规空间。不间断的空格表示该行不应在该点处换行,就像它不会在一个单词的中间换行一样。 此外,正如斯文德(Svend)在其评论中指出的那样,不间断的空间不会崩溃。
本文向大家介绍<%# %> 和 <% %> 有什么区别?相关面试题,主要包含被问及<%# %> 和 <% %> 有什么区别?时的应答技巧和注意事项,需要的朋友参考一下 答:<%# %>表示绑定的数据源 <%%>是服务器端代码块
问题内容: 以下代码之间有什么区别: 和 Python建议采用一种做事方式,但有时似乎不止一种。 问题答案: 一个是函数调用,一个是文字: 使用第二种形式。它更具Python风格,并且可能更快(因为它不涉及加载和调用单独的函数)。
发展至今(2020 年 6 月份),GCC 编译器已经更新至 10.1.0 版本,其功能也由最初仅能编译 C 语言,扩增至可以编译多种编程语言,其中就包括 C++ 。 除此之外,当下的 GCC 编译器还支持编译 Go、Objective-C,Objective-C ++,Fortran,Ada,D 和 BRIG(HSAIL)等程序,甚至于 GCC 6 以及之前的版本还支持编译 Java 程序。但本