关于HashMap问题二
来源:互联网 发布:linux更换网卡 编辑:程序博客网 时间:2024/06/06 06:41
在最近参加的一次某国内知名公司实习生面试中,被问到了HashMap的底层实现,让我说一下,我当时说是散列表,然后把怎么存储,怎么取,什么比较hashcode,equals说了一堆,然后面试官问我,如果两个hashmap放了相同的一个key怎么办?
当时懵了。。。。。。
回来后看了下源码,发现这块是一个数组实现的,每一个hashmap会维护自己的一个entry数组,这个数组的大小必须是2的n次方,如果出现相同的hashcode时,则会用链表处理,entry类中有一个next指向了下一个entry,这样也就是说如果hashmap中元素hashcode均不同时查询速度可以达到o(1),但是,如果有用到entry的链表的话是需要遍历链表的,会降低hashmap的效率,所以在实现hashcode时,需要返回尽量不同的hashcode。
0 0
- 关于HashMap问题二
- HashMap巩固二:多线程问题
- 关于hashmap的遍历问题
- 关于hashmap的遍历问题
- 关于HashMap的拷贝问题
- 关于HashMap的使用问题
- 关于hashmap put 的问题
- 关于HashMap的一些问题
- 关于freemarker里面的hashmap使用问题
- 关于freemarker里面的hashmap使用问题
- 关于java中HashMap遍历效率问题
- 关于java的HashMap的问题
- 关于hashmap使用迭代器的问题
- 关于HashMap底层的一些问题
- 关于汉诺塔问题二
- 关于HashMap
- 关于hashmap
- 关于map的数据排序问题(hashmap,treemap)
- zoj 3869 Ace of Aces
- 我来说说操作系统中 死锁与饥饿的区别辨析
- 转载:2014 Top Security Tools as Voted by ToolsWatch.org Readers
- 作业1
- 多线程对比linkedList和arrayList的add方法
- 关于HashMap问题二
- 一个链式存储的例子(图片)
- 如何让两个div处于一行
- PHP源码分析-变量的存储方式
- mini2440硬件篇之看门狗
- js 中读取JSON的方法探讨
- 黑马程序员——正则表达式
- 提高Oracle查询效率
- 妙龄女台北地铁裸拍 公然露乳露下体(图)