SparseArray ArrayMap HashMap 区别

一直以来,在项目中需要使用到这类的数据结构式,都习惯性的想到HashMap,也没有关心过
其他的问题。
SparseArray
最近偶然看到SparseArray这种数据结构,才发现原来android内部是推荐使用这种数据结构的,由于Android对应的设备内存相对来说比较小,因而内存是比较稀罕的东西,而SparseArray
恰好是存储的内存相对来说比较小。在某些条件下性能更好,主要是由于它避免了对key的自己主动装箱(int转为Integer类型),它内部则是通过两个数组来进行数据存储的。一个存储key,另外一个存储value,为了优化性能,它内部对数据还採取了压缩的方式来表示稀疏数组的数据,从而节约内存空间。
private int[] mKeys;
private Object[] mValues;这是SparseArray源码中定义的两个数组对象,很容易就可以知道mKey是保存key值得数组,而mValues就是保存value值得数据对象。

这是源码中取得value值的代码片段,可以看出是通过二分法来获取value值的,同样put也是这样去插入值得.
所以在获取数据的时候,比hashMap去遍历查询要快的多。当然在key值上面只能使用int类型可能是这个数据结构的不足之处吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值