HashMap 简介

1. HashMap 工作原理

基于hashing原理,通过put()和get()方法存取对象。

当将k-v传递给put()时,它调用key对象的hashcode()来计算hashcode,然后找到bucket位置来存储对象。获取对象时,通过key对象的equals()找到正确的k-v,然后返回值对象。

HashMap使用链地址法来解决碰撞问题,当发生碰撞时,对象将存储在链表的下一节点中,(HashMap在每个链表节点中存储k-v对象)。

当两个不同的key对象的hashcode相同时,它们会存储在同一个bucket位置的链表中,key对象的equals()用来找到k-v。

2. HashMap与HashSet的区别

实现接口存储插入元素   速度计算hashcode值
HashMap    Mapk-vput()较快(使用唯一的key来获取对象)使用key对象
HashSet   Set(仅仅存储)对象add()比较慢使用成员对象(若hashcode相同,则使用equals()来判断对象的相等性)

3. HashMap与TreeMap的区别

   实现存储  遍历   k-v安全性  效率
HashMaphash表(AbstractMap)无序的随机的key,value可以为null非并发安全   高
TreeMapSortMap接口,基于红黑树默认按键的升序排序的不允许为null非并发安全   低

4. HashSet与TreeSet的区别

实现存储增删复杂度k-v效率怎么区分重复数据
HashSethash表无序,不重复o(1)能且只能放入一个null快(通常使用)依靠Comparable
TreeSet树形结构有序,不重复o(logn)不允许放入null依靠hashcode(),equals()

5. HashMap与HashTable的区别

1. 二者都实现了map、cloneable、serializable 接口,但HashMap继承自AbstractMAP类,而HashTable继承自Dictionary类(已废弃)。

2. HashMap允许键key和value为null;而HashTable则不允许key或value为null;在HashMap中,null可以作为键,但这样的key只有一个,当get()方法返回null时,可能是没有该key,也可能是该key所对应的值为null,所以不能由get() 来判断HashMap中是否存在某个key,而应用containkey()来判断。

3. HashMap非同步(线程不安全),适合于单线程,但效率很快;HashTable 是线程安全的,适合于多线程,但由于效率低,现在已基本废弃。

4. 初始容量大小和每次扩容大小不同。

初始容量扩充容量
HashMap162n
HashTable112n+1

5. 两者都提供了可迭代的键的集合,HashTable还提供了键的枚举。

6. hash 值的计算方法不同,HashTable用的是obj的hashcode()。

7. HashMap 不能保证随着时间的推移,map中的元素次序是不变的。

11

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值