java – 为什么在LinkedHashMap中迭代桶的速度比HashMap快?

我很难理解这一点.

谷歌搜索,我发现

“HashMap iterator has to iterate through all the buckets including
empty buckets”

“in LinkedHashMap all the entries are doubly linked”.

如果是这种情况,为什么唯一的HashMap必须迭代空桶,而不是LinkedHashMap,尽管两者都使用相同的桶概念实现?所有条目都是双重联系的,意思是“所有的桶和元素都是双重联系的”,或者只是“元素是双重联系的”.

请给我一个解释LinkedHashMap中双向链接桶实现的图表.

提前谢谢了.

解决方法

LinkedHashMap存储桶节点(条目)保存额外的两个指针(之前,之后)以维持顺序.

这是创建时的结构.

Map<Integer,String> linkedHashMap = new LinkedHashMap<Integer,String>();

现在让我们添加一个元素.

linkedHashMap.put(1,"obj1");

这里是linkedHashMap标头之前,之后是指向入口对象.

让我们添加一个元素.

linkedHashMap.put(15,"obj15");

检查指针随红色前一状态的变化

让我们再添加一个元素.

linkedHashMap.put(4,"obj4");

当另一个条目插入相同的哈希时,每个条目中的下一个指针形成SingleLikedList.

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...