之前看到一篇关于adapter的文章用到了SparseArray,所以在这里写写关于SparseArray的使用方法。

SparseArray是官方针对安卓所写的容器,与HashMap类似,只是性能比HashMap好。

SparseArray实现了Cloneable接口,还能够调用clone方法。

首先看看SparseArray的使用方法:

构造:

SparseArray的构造与我们用惯的HashMap,ArrayList一样也是new出一个实例然后使用。

SparseArray<E> sa=new SparseArray<E>();

顺便提一下java1.7支持这样写:

SparseArray<E> sa=new SparseArray<>();

也能够在构造的时候就指定大小:

SparseArray<E> sa=new SparseArray<E>(11);

假设构造的时候不指定大小,则默觉得10

加入元素:

用惯ArraList和HashMap的我们知道要往容器里面加入元素能够分别调用add和put方法。
SparseArray也一样,能够调用put(int key,E value);
相信有读者一经发现上面构造SparseArray的时候已经发现,构造的时候仅仅指定一个泛型,而不像HashMap那样构造的时候要指定两个泛型类型:
new HashMap<String,String>(); 
仅仅须要这样:
SparseArray<E> sa=new SparseArray<E>();

那是由于SparseArray的键仅仅能是int形式所以构造的时候仅仅指定值得泛型就可以。

同一时候也就是说,仅仅能在键为int形式的时候能够使用SparseArray其他情况还是须要使用Map。

除了put方法能够往SparseArray加入元素之外,还能够通过append加入元素。

public void append(int key, E value) 

SparseArray储存数据是使用二分法储存。说储存的数据是依据键的大小,从小到大排列。


取值:

既然能够加入那么自然能够取出来:

public E get(int key) ;

依据键取值。

除此之外另一个方法能够取值:
public E get(int key, E valueIfKeyNotFound) ;

能够看到多了一个參数,从第二个參数的名字能够猜到。当找不到该键的值得时候默认使用第二个參数的值。


除了按键取值之外还能够按顺序取键。按顺序取值:
查看第几个位置的值:
public int keyAt(int index)  
查看第几个位置的键:
public E valueAt(int index)  

假设所查的键或值没有的话会返回负数。

删除:

delete(int  key)

remove(int key)  delete与remove的效果是一样的这里不多说
除此之外还有:
removeAt(int index)
//按顺序删除
clear() 所有清空

改:

public void setValueAt(int index, E value)
public void put(int key, E value)

setValueAt能够将index位置上的值改成value

而put方法前面说过。假设说put进去的键已经存在那么就会覆盖,达到改动的效果。

假设put进去的键还没有的话就添加。




说完主要的增删改查再扯一下其他:

既然官方推荐使用SparseArray,那么在编码过程中遇到键为int形式的则尽量使用SparseArray取代map。



















Android:使用SparseArray取代HashMap优化性能的更多相关文章

  1. 73.Android之SparseArray替代HashMap

    转载:https://liuzhichao.com/p/832.html HashMap是java里比较常用的一个集合类,我比较习惯用来缓存一些处理后的结果.最近在做一个Android项目,在代码中定 ...

  2. Android内存优化(使用SparseArray和ArrayMap取代HashMap)

    在Android开发时,我们使用的大部分都是Java的api,比方HashMap这个api,使用率非常高,可是对于Android这样的对内存非常敏感的移动平台,非常多时候使用一些java的api并不能 ...

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

    HashMap是java里比较常用的一个集合类,我比较习惯用来缓存一些处理后的结果.最近在做一个Android项目,在代码中定义这样一个变量,实例化时,Eclipse却给出了一个 performanc ...

  4. 关于Android中ArrayMap/SparseArray比HashMap性能好的深入研究

    由于网上有朋友对于这个问题已经有了很详细的研究,所以我就不班门弄斧了: 转载于:http://android-performance.com/android/2014/02/10/android-sp ...

  5. 性能优化:使用SparseArray代替HashMap<Integer,Object>(转)

    HashMap是java里比较常用的一个集合类,我比较习惯用来缓存一些处理后的结果.最近在做一个Android项目,在代码中定义这样一个变量,实例化时,Eclipse却给出了一个 performanc ...

  6. SparseArray替代HashMap来提高性能

    SparseArray是 Android框架独有的类,在标准的JDK中不存在这个类.它要比 HashMap 节省内存,某些情况下比HashMap性能更好,按照官方问答的解释,主要是因为SparseAr ...

  7. Android开发 使用SparseArray代替HashMap[转载]

    源作者:Android小Y链接:https://www.jianshu.com/p/1828f14d7955来源:简书 前言 Android开发中,一个好的应用,除了要有吸引人的功能和交互之外,在性能 ...

  8. 使用SparseArray代替HashMap

    HashMap是java里比较常用的一个集合类,我比较习惯用来缓存一些处理后的结果.最近在做一个Android项目,在代码中定义这样一个变量,实例化时,Eclipse却给出了一个 performanc ...

  9. Android 之SparseArray<E>详解

    SparseArray是android里为<Interger,Object>这样的Hashmap而专门写的class,目的是提高效率,其核心是折半查找函数(binarySearch) pr ...

随机推荐

  1. 87. [NOIP2000] 乘积最大

    ★☆   输入文件:cjzd.in   输出文件:cjzd.out   简单对比 时间限制:1 s   内存限制:128 MB 问题描述 今年是国际数学联盟确定的“2000——世界数学年”,又恰逢我国 ...

  2. redis学习-字典

    1.字典作用 实现数据库键空间(key space): 用作 Hash 类型键的底层实现之一: 2.字典实现的数据结构 typedef struct dict { // 特定于类型的处理函数 dict ...

  3. Android 百度地图 android.view.InflateException: Binary XML file line Error inflating class com.baidu.mapapi.map.MapView

    android.view.InflateException: Binary XML file line Error inflating class com.baidu.mapapi.map.MapVi ...

  4. Spring框架系列(三)--Bean的作用域和生命周期

    Bean的作用域 Spring应用中,对象实例都是在Container中,负责创建.装配.配置和管理生命周期(new到finalize()) Spring Container分为两种: 1.BeanF ...

  5. IOS上MediaPlayer framework实现视频播放

    播放电影文件: iOS sdk中可以使用MPMoviePlayerController来播放电影文件.但是在iOS设备上播放电影文件有严格的格式要求,只能播放下面两个格式的电影文件. • H.264 ...

  6. Python学习笔记(1)对象类型

    强制转换字符串函数str 如果我们求2的一百万次方是多少那么我们可以 print(2**1000000) 如果我们要求2的一百万次方有多少位那么我们可以用str函数强制转换成字符串然后len函数计算 ...

  7. 以gnome-terminal为例,修改gnome3 的默认配置

    gnome连续几个版本的terminal默认配置文件都是同一个配置文件“b1dcc9dd-5262-4d8d-a863-c897e6d979b9”.这是因为gnome的developers编辑了这个配 ...

  8. linux strings-在对象文件或二进制文件中查找可打印的字符串

    推荐:更多Linux 文件查找和比较 命令关注:linux命令大全 strings命令在对象文件或二进制文件中查找可打印的字符串.字符串是4个或更多可打印字符的任意序列,以换行符或空字符结束. str ...

  9. PHP 生成器Generators的入门理解和学习

    什么是生成器Generators 生成器允许你在 foreach 代码块中写代码来迭代一组数据而不需要在内存中创建一个数组, 那会使你的内存达到上限,或者会占据可观的处理时间.相反,你可以写一个生成器 ...

  10. odoo domain详解

    参考的以下文档: luohuayong:Odoo domain写法及运用 baimo:odoo domain表达式 1.domain 表达式规则 最简单的格式:[('字段名','操作符',值)] 例: ...