SparseArray一些要点

名词:
auto-boxing:
自动装箱(将java中的基本数据类型转换成相应的包装类。 比如Integer i = 1;就会将1装换为一个Integer的对象。)
简介:
SparseArray将整数索引对象,不像一般的数组(索引间有内存间隔),它比HaspMap用Integer索引对象更加省内存。
原因大概有两个:
1:避免了auto-boxing
2:它本身的数据结构在每次mapping的时候都不需要一个额外的输入对象
SparseArray也是一般的数组结构,用二进制查询的方式进行索引,所以它要比HashMap要慢,如果1000以下的数据量,效率也不会慢很多吧,50%以下。
为了优化性能,SparseArray在移除keys的时候做出了优化:不立即删除entry压缩数组,而是标记entry为deleted,然后entry以后可以重用,直到下次garbage collection的时候才处理(garbage collection 将在SparseArray被检索,大小需要增加的时候调用)。

用法:
常用的就是增删改查:

Paste_Image.png
Paste_Image.png

//删除的时候先标记entry为DELETE,再将mGarbage改为true,随时等待回收


Paste_Image.png

//增加的时候用append代替put防止数据越界


Paste_Image.png

if(mGarbage)
gc();
如果需要回收,就先回收
Paste_Image.png
Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,896评论 18 399
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,293评论 19 139
  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 5,385评论 0 3
  • (一)Java部分 1、列举出JAVA中6个比较常用的包【天威诚信面试题】 【参考答案】 java.lang;ja...
    独云阅读 11,924评论 0 62
  • 有时候当一个聪明人很不容易,他睡觉比别人醒的早,能比别人更先意识到危险的来临。当你领导一群人时,你必须每次都做到万...
    风行天避阅读 1,040评论 0 0