Stream
接口中的count()
方法与Collector
中的count()
方法之间有什么区别吗?一般应该使用哪一个?使用一个比另一个有任何性能优势吗?
// creating a stream of strings
Stream<String> s = Stream.of("1", "2", "3", "4");
// using Collectors counting() method to
// count the number of input elements
long ans = s.collect(Collectors.counting());
// displaying the required count
System.out.println(ans);
如果要计算(所有)流元素,请使用count()
返回此流中元素的计数。这是减少的特殊情况,相当于:
return mapToLong(e -> 1L).sum();
需要对计数进行分组时,请使用counting(),如下所示:
Map<String, Long> collect =
wordsList.stream().collect(groupingBy(Function.identity(), counting()));
一个区别在于实现。这记录在流中。count()(至少在版本9上):
如果实现能够直接从流源计算计数,则可以选择不执行流管道(顺序或并行)。在这种情况下,将不会遍历任何源元素,也不会计算任何中间操作。。。
试试这个:
System.out.println(Stream.of(1, 2, 3, 4, 5)
.map(i -> {
System.out.println("processing " + i);
return i * 2;
}).count());
System.out.println(Stream.of(1, 2, 3, 4, 5)
.map(i -> {
System.out.println("processing " + i);
return i * 2;
}).collect(Collectors.counting()));
两者都会给出正确的计数,但第一个可能会跳过map()的执行,因此可能不会显示println的输出。如文档所述,这是实现细节(count()
如果可以在不执行管道的情况下确定元素的数量,则可以跳过中间操作)
问题内容: 两者都意味着空间,但是有什么区别吗? 问题答案: 一个是不间断空间,另一个是常规空间。不间断的空格表示该行不应在该点处换行,就像它不会在一个单词的中间换行一样。 此外,正如斯文德(Svend)在其评论中指出的那样,不间断的空间不会崩溃。
本文向大家介绍<%# %> 和 <% %> 有什么区别?相关面试题,主要包含被问及<%# %> 和 <% %> 有什么区别?时的应答技巧和注意事项,需要的朋友参考一下 答:<%# %>表示绑定的数据源 <%%>是服务器端代码块
问题内容: 以下代码之间有什么区别: 和 Python建议采用一种做事方式,但有时似乎不止一种。 问题答案: 一个是函数调用,一个是文字: 使用第二种形式。它更具Python风格,并且可能更快(因为它不涉及加载和调用单独的函数)。
文档说 设置在将屏幕外视图添加到可能共享的回收视图池之前要保留的屏幕外视图数。 和 设置丢弃前池中可容纳的最大视图持有者数量。 但是,它们不是都充当从中获取视图的缓存(即,第一个设置RV缓存的视图数,而第二个设置RVP的视图数)吗? 此外,当需要视图时,首先从RVP或RV的缓存中获取视图的位置? 对于一个简单的非嵌套回收视图,两者的最佳(滚动方式,忽略内存)配置是什么?
发展至今(2020 年 6 月份),GCC 编译器已经更新至 10.1.0 版本,其功能也由最初仅能编译 C 语言,扩增至可以编译多种编程语言,其中就包括 C++ 。 除此之外,当下的 GCC 编译器还支持编译 Go、Objective-C,Objective-C ++,Fortran,Ada,D 和 BRIG(HSAIL)等程序,甚至于 GCC 6 以及之前的版本还支持编译 Java 程序。但本
问题内容: 比较PMD和CheckStyle有一个问题。但是,我找不到关于PMD和FindBugs之间差异/相似性的详尽分类。我相信一个关键的区别是PMD适用于源代码,而FindBugs适用于编译的字节码文件。但是就功能而言,这应该是一个选择,还是两者相辅相成? 问题答案: 我同时使用。我认为他们是相辅相成的。 正如您所说,PMD在源代码上工作,因此会发现诸如以下问题:违反命名约定,缺少花括号,放