SparseArray、ArrayMap

SparseArray与ArrayMap都是Android提供的两个列表数据结构,它们采用的是以时间换空间的方式来提高效率。增加时间投入减少内存占用。

SparseArray稀疏数组,它采用压缩的方法存储稀疏数组中的内容。SparseArray是android里为<Interger,Object>这样的整型Key-对象Value的HashMap而专门写的类,目的是节省内存提高内存效率,其核心是折半查找函数(binarySearch)。

Bundle内部是由ArrayMap实现的,ArrayMap的内部实现是两个数组,一个int数组是存储对象数据对应下标,一个对象数组保存key和value,内部使用二分法对key进行排序,所以在添加、删除、查找数据的时候,都会使用二分法查找,只适合于小数据量操作,在数据量比较大的情况下它的性能将退化。

而HashMap内部则是数组+链表结构,所以在数据量较少的时候, HashMap的Entry Array比ArrayMap占用更多的内存。因为使用Bundle的场景大多数为小数据量, 在两个Activity之间传递数据的场景下使用 ArrayMap保存数据,在操作速度和内存占用上都具有优势,因此使用Bundle来传递数据,可以保证更快的速度和更少的内存占用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值