SparseArray<E>来替代HashMap,获取更好性能

今天看到一个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)
时间: 2024-10-22 15:52:51

SparseArray<E>来替代HashMap,获取更好性能的相关文章

73.Android之SparseArray替代HashMap

转载:https://liuzhichao.com/p/832.html HashMap是java里比较常用的一个集合类,我比较习惯用来缓存一些处理后的结果.最近在做一个Android项目,在代码中定义这样一个变量,实例化时,Eclipse却给出了一个 performance 警告. sparsearray 意思就是说用SparseArray <E> 来替代,以获取更好性能.老实说,对SparseArray并不熟悉,第一感觉应该是Android提供的一个类.按住Ctrl点击进入SparseAr

SparseArray替代hashmap

最近编程时,发现一个针对HashMap<Integer, E>的一个提示: 翻译过来就是:用SparseArray<E>来代替会有更好性能. 那我们就来看看源码中SparseArray到底做了哪些事情: 一.构造 从构造方法我们可以看出,它和一般的List一样,可以预先设置容器大小,默认的大小是10: [java] view plaincopy public SparseArray() { this(10); } public SparseArray(int initialCapa

android SparseArray替代HashMap的分析

SparseArray是Android框架独有的类,在标准的JDK中不存在这个类.它要比 HashMap 节省内存,某些情况下比HashMap性能更好,按照官方问答的解释,主要是因为SparseArray不需要对key和value进行auto-boxing(将原始类型封装为对象类型,比如把int类型封装成Integer类型),结构比HashMap简单(SparseArray内部主要使用两个一维数组来保存数据,一个用来存key,一个用来存value)不需要额外的额外的数据结构(主要是针对HashM

Android内存优化(使用SparseArray和ArrayMap代替HashMap)

转载自:http://blog.csdn.net/u010687392/article/details/47809295 在Android开发时,我们使用的大部分都是Java的api,比如HashMap这个api,使用率非常高,但是对于Android这种对内存非常敏感的移动平台,很多时候使用一些java的api并不能达到更好的性能,相反反而更消耗内存,所以针对Android这种移动平台,也推出了更符合自己的api,比如SparseArray.ArrayMap用来代替HashMap在有些情况下能带

Ab3d.PowerToys 3D辅助库更好性能的3Dlines实现

Ab3d.PowerToys是与WPF 3D一起使用的辅助库. 该库的主要部分是: Cameras (SceneCamera, FirstPersonCamera, ThirdPersonCamera, 等) Camera Controllers (MouseCameraController, CameraControlPanel) 3D Models and Visuals (Sphere, Box, Cylinder,等) 3D Lines Event Manager 3D (简化了3D对象

Android应用性能优化之使用SparseArray替代HashMap

一.概述 最近在项目中看到了SparseArray,好奇研究了下. SparseArray是Android框架独有的类,在标准的JDK中不存在这个类.它要比 HashMap 节省内存,某些情况下比HashMap性能更好,按照官方问答的解释,主要是因为SparseArray不需要对key和value进行auto-boxing(将原始类型封装为对象类型,比如把int类型封装成Integer类型),结构比HashMap简单(SparseArray内部主要使用两个一维数组来保存数据,一个用来存key,一

在XcodeGhost事件之后,获取更纯净的Xcode的方法。

正值Xcode 7的更新,IOS界就冒出了个甚至可以说成涉及国家安全的大事也不为过: 也可以点击网址链接看总结的更完整的文章:众多知名 APP 都中毒了,XCodeGhost 病毒事件汇总 然后我就想着如何获取从apple官网下载并同时能够获取纯净的Xcode 7正式版源文件. 然后我就问了问度娘,找到了文章:Mac下获取AppStore安装包文件路径 一开始不确定,然后尝试了可行.在这篇文章的基础上,我重新并且添加了我执行过程中遇到的新问题或者是新做法,由于时间缘故,和Mac下获取AppSto

Map/HashMap 获取Key值的方法

1.通过  KeySet()方法 Map<String,Student> newmap = new HashMap<String,Student>(); //newmap HaspMap类型的集合 有唯一的Key,一个Key对应相应的学生 Student stu = new Student("11","Mary","79"); //创建一个学生对象 学号11; 姓名 Mary 成绩 79 newmap.put("

java中hashmap获取list

首先我们将list存入到map中,如何快速获取list呢 我在网站找到两种方式 HashMap<String, String>hm=new HashMap<String, String>();方式1Iterator iterator = hm.keySet().iterator();while(iterator.hasNext()) {System.out.println(hm.get(iterator.next()));}方式2Set set = hm.entrySet() ;j