ConcurrentHashMap.newKeySet() vs Collections.newSetFromMap()(ConcurrentHashMap.newKeySet() 与 Collections.newSetFromMap())
问题描述
Java 8 引入了获取并发 Set
实现的新方法
Java 8 introduced new way to obtain a concurrent Set
implementation
// Pre-Java-8 way to create a concurrent set
Set<String> oldStyle = Collections.newSetFromMap(new ConcurrentHashMap<>());
// New method in Java 8
Set<String> newStyle = ConcurrentHashMap.newKeySet();
有什么理由更喜欢新方法吗?
Is there any reason to prefer new method?
有什么优点/缺点?
推荐答案
ConcurrentHashMap.newKeySet()
应该更高效一些,因为它移除了单层间接.Collections.newSetFromMap(map)
主要是基于将操作重定向到map.keySet()
,而ConcurrentHashMap.newKeySet()
则非常接近 map.keySet()
本身(仅具有附加支持).
ConcurrentHashMap.newKeySet()
should be somewhat more efficient as removes a single level of indirection. Collections.newSetFromMap(map)
is mostly based on redirecting the operations to the map.keySet()
, but ConcurrentHashMap.newKeySet()
is very close to map.keySet()
itself (just with additions support).
至于功能,我认为没有区别.
As for functionality, I see no difference.
这篇关于ConcurrentHashMap.newKeySet() 与 Collections.newSetFromMap()的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:ConcurrentHashMap.newKeySet() 与 Collections.newSetFromMap()
基础教程推荐
- 降序排序:Java Map 2022-01-01
- Java Keytool 导入证书后出错,"keytool error: java.io.FileNotFoundException &拒绝访问" 2022-01-01
- 设置 bean 时出现 Nullpointerexception 2022-01-01
- 无法使用修饰符“public final"访问 java.util.Ha 2022-01-01
- FirebaseListAdapter 不推送聊天应用程序的单个项目 - Firebase-Ui 3.1 2022-01-01
- 减少 JVM 暂停时间 >1 秒使用 UseConcMarkSweepGC 2022-01-01
- 在 Libgdx 中处理屏幕的正确方法 2022-01-01
- Java:带有char数组的println给出乱码 2022-01-01
- 如何使用 Java 创建 X509 证书? 2022-01-01
- “未找到匹配项"使用 matcher 的 group 方法时 2022-01-01