当前位置: 首页 > 面试题库 >

ConcurrentHashMap jdk 8使用TreeNodes代替List ..为什么?

葛昱
2023-03-14
问题内容

嗨,我知道ConcurrentHashMapJDK 8之前的工作原理。我也理解了代码:它是模块化的,而且很难理解。

ConcurrentHashMapJDK 8中的代码与以前的实现相比已发生了很大变化。

由于此问题被归类为过于广泛,因此我现在将尝试非常具体。

CHMv8使用TreeBin(RedBlackTree的变体)存储桶,而不是使用链表。

所以我的问题是使用TreeBin而不是链接列表的主要优点是什么?

源代码在这里


问题答案:

主要更改是添加ConcurrentHashMap了新Java
8默认Map方法的特定实现,并具有依赖于内部细节的更好的并发实现。这些更改需要大量新的内部类,这些内部类使.java文件膨胀

例如,其中一些方法包括:

计算(K键,BiFunction
remappingFunction)

forEach(BiConsumer操作)

合并(K键,V值,BiFunction
remappingFunction)

仅举几个。

我认为这也说明了为什么您通常不必关心无需维护类的工作方式的实现细节。只要该类遵循其javadoc中规定的约定,您就应该对它的工作方式不可知,因为将来实现的详细信息可能会更改。



 类似资料:
  • 问题内容: 在PHP页面上的表单中,可以使用: 要么 要么 在表单的动作属性中。由于echo 不会传递要使用的变量,而您必须使用,为什么还要使用它呢? 我问是因为我花了一些时间才弄清楚这些变量没有随传递。谢谢。 问题答案: 该属性将默认为当前URL。这是“将表格提交到它来自的地方的最可靠,最简单的方法”。 没有理由使用,并且根本不提交表单(除非附加了事件处理程序来处理提交)。

  • 问题内容: 另一个针对Java的构建工具到底能给我带来什么? 如果您在其他工具上使用Gradle,为什么? 问题答案: 我不会用Gradle来激怒自己(到目前为止只是一个玩具项目) [作者表示,到目前为止,他们仅在一个玩具项目上使用了Gradle,而不是Gradle是一个玩具项目-请参阅评论] ,但我要说的是人们之所以考虑使用它的原因是因为Ant和Maven的挫败感。 以我的经验,Ant通常是只写

  • 问题内容: 该方法(可以接在执行)如下: 我想知道在这种情况下我们可以代替使用吗?喜欢 既然ArrayList类iteself已经是通用的,那么我们可以使用它代替新的通用类型吗? 问题答案: 的要点是,如果所需的数组是的基类。例如,如果为,但所需的数组为。如果被锁定到这是不可能的。 由于类型擦除,在通用集合/类型中不需要这种类型的东西。但是数组没有类型擦除,因此数组的类型非常重要。

  • 问题内容: 在Java中,有人告诉我在执行null检查时应使用==而不是.equals()。是什么原因呢? 问题答案: 他们是完全不同的两件事。比较变量包含的对象引用(如果有)。根据相等性的含义检查两个对象是否相等。根据它们的契约,两个不同的对象实例完全有可能“相等”。还有一个小细节,因为这是一个方法,所以如果你尝试在引用上调用它,则会得到一个。 例如:

  • 问题内容: 如果我理解正确,那么Javascript中的每个对象都是从Object原型继承的,这意味着Javascript中的每个对象都可以通过其原型链访问hasOwnProperty函数。 在阅读require.js的源代码时,我偶然发现了该函数: 是对的引用。将此功能编写为 既然如此,我们为什么要完全定义此功能?是否只是为了获得(少量)性能提升而使用快捷方式和对属性访问进行本地缓存的问题,还是

  • 问题内容: 为什么我们不能仅将所有测试用例记录在 Selenium IDE中 ,将其导出到 Java / WebDriver 并在带有Eclipse的 WebDriver中 运行呢? 我需要明确的解释,因为我对使用WebDriver非常困惑! 谁能解释为什么IDE录制的脚本在WebDriver中失败? 问题答案: 为什么我们不能只在IDE中记录所有测试用例,将其导出到java / webdrive