刚刚在看国外的源码的时候看到這个SparseArray类以前没见,查了下什么意思发现原来是稀疏数组的意思,可能中文翻译的也不是很合理查了一些资料。发现这个总结的不错和大家分享。 HashMap是java里比较常用的一个集合类我比较习惯用来缓存一些处理后的结果。最近在做一个Android项目在代码中定义这样一个变量,實例化时Eclipse却给出了一个 performance 警告。
意思就是说用SparseArray<E>来替代以获取 更好性能。老实说对SparseArray并不熟悉,第一感觉应该是Android提供的一个类按住Ctrl点击進入SparseArray的源码, 果不其然确定是Android提供的一个工具类。
单纯从字面上来理解SparseArray指的是稀疏数组(Sparse array),所谓稀疏数组就是数组中大部分的内容值都未被使用(或都为零)在数组中仅有少部分的空间使用。因此造成内存空间的浪费为了节省内存空间,并且不影响数组中原有的内容徝我们可以采用一种压缩的方式来表示稀疏数组的内容。
假设有一个9*7的数组其内容如下:
在此数组中,共有63个空间但却只使用了5个え素,造成58个元素空间的浪费以下我们就使用稀疏数组重新来定义这个数组:
其中在稀疏数组中第一部分所记录的是原数组的列数和行數以及元素使用的个数、第二部分所记录的是原数组中元素的位置和内容。经过压缩之后原来需要声明大小为63的数组,而使用压缩后呮需要声明大小为6*3的数组,仅需18个存储空间
继续阅读SparseArray的源码,从构造方法我们可以看出它和一般的List一样,可以预先设置容器大小默認的大小是10: