SparseArray<E>来替代HashMap,获取更好性能
来源:互联网 发布:windows.h x86 x64 编辑:程序博客网 时间:2024/06/05 17:19
今天看到一个SparseArray的类,查下相关资料进行总结。
SparseArray指的是稀疏数组(Sparse array),所谓稀疏数组就是数组中大部分的内容值都未被使用(或都为零),在数组中仅有少部分的空间使用。因此造成内存空间的浪费,为了节省内存空间,并且不影响数组中原有的内容值,我们可以采用一种压缩的方式来表示稀疏数组的内容。
从构造方法我们可以看出,它和一般的List一样,可以预先设置容器大小,默认的大小是10,是Android提供的一个工具类
单纯从字面上来理解,SparseArray指的是稀疏数组(Sparse array),所谓稀疏数组就是数组中大部分的内容值都未被使用(或都为零),在数组中仅有少部分的空间使用。因此造成内存空间的浪费,为了节省内存空间,并且不影响数组中原有的内容值,我们可以采用一种压缩的方式来表示稀疏数组的内容。
SparseArray用来取代HashMap<Integer, Object>
SparseBooleanArray用来取代HashMap<Integer, Boolean>
SparseIntArray用来取代HashMap<Integer, Integer>
假设有一个9*7的数组,其内容如下:
在此数组中,共有63个空间,但却只使用了5个元素,造成58个元素空间的浪费。以下我们就使用稀疏数组重新来定义这个数组:
其中在稀疏数组中第一部分所记录的是原数组的列数和行数以及元素使用的个数、第二部分所记录的是原数组中元素的位置和内容。经过压缩之后,原来需要声明大小为63的数组,而使用压缩后,只需要声明大小为6*3的数组,仅需18个存储空间。
使用方法:添加
public void put(int key, E value) {}public void append(int key, E value){}
删除:
public void delete(int key) {}public void remove(int key) {} //直接调用的delete(int key)public void removeAt(int index){}public void clear(){}修改:
public void put(int key, E value)public void setValueAt(int index, E value)
修改数据起初以为只有setValueAt(int index, E value)可以修改数据,但后来发现put(int key, E value)也可以修改数据,我们查看put(int key, E value)的源码可知,在put数据之前,会先查找要put的数据是否已经存在,如果存在就是修改,不存在就添加。
查找:
public E get(int key)
public E get(int key, E valueIfKeyNotFound) public E valueAt(int index)
- SparseArray<E>来替代HashMap,获取更好性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap来提高性能
- SparseArray替代HashMap提高性能
- 当用到Map<Integer,E>的使用,用SparseArray<E>替代性能更好
- SparseArray替代HashMap----Android应用性能优化
- 性能优化——SparseArray替代HashMap
- Android SparseArray替代HashMap
- 电视端屏幕适配
- Bullet2.8手册翻译(2)
- 适合自学的C语言基础视频教程
- 浅谈Java中的hashcode方法
- 在Ubuntu上安装Tegra Android Development Pack,一键安装ubuntu 上的eclipse opencv4android的开发环境
- SparseArray<E>来替代HashMap,获取更好性能
- Linux查看每个CPU负载及进程IO
- Intent复习回顾
- 关于IOS滚动视图
- JVM类加载机制
- Go 语言编译运行的小问题
- (cocos2d-js游戏)选择字体的颜色
- 如何实现Android应用的静默安装
- 最小费用最大流模板