LinkedHashMap和hashMap的区别

LinkedHashMap继承于HashMap,底层基于HashMap和双向链表来实现的。

HashMap无序,LinkedHashMap有序,可分为插入顺序和访问顺序两种。

如果是访问顺序,那put和get操作已经存在的Entry时都会把Entry移动到双向链表的标为(先删除再插入)。遍历时按照插入顺序排序,原因在于LinkedHashMap的内部类LinkedHashIterator,执行Iterator.next访问链表的下一个元素,所以可以按照插入顺序的输出。

LinkedHashMap存储数据,还是跟HashMap一样使用Entry的方式,双向链表只是为了保证顺序。

HashMap的遍历速度和他的容量有关,而LinkedHashMap只跟实际数量有关。

LinkedHashMap按照插入顺序排序,HashMap基于哈希表乱序。

基于LinkedHashMap实现,如:Mybatis框架中的LruCache

基于HashMap实现,如:Mybatis框架中的PerpetualCache

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值