SparseArray<E>详解
SparseArray<E> 是官方推荐的用来替代 HashMap<Integer, E> 的一个工具类,相比来说有着更好的性能(其核心是折半查找函数(binarySearch))。
通过源码来看下SparseArray<E>的一些使用特点:
-------------------------------------------------------------------------------------------------------
1、SparseArray可以预先设置容器大小,默认是10
/**
* Creates a new SparseArray containing no mappings.
*/
public SparseArray() {
this();
}
-------------------------------------------------------------------------------------------------------
2、增删改查
(1)两种添加数据的方法
public void put(int key, E value)
public void append(int key, E value)
其中append()内部调用了put()
put()内部又使用了二分法存储数据,由此可见:它存储的数值都是按键值从小到大的顺序排列好的
static int binarySearch(int[] array, int size, int value) {
int lo = ;
int hi = size - ; while (lo <= hi) {
final int mid = (lo + hi) >>> ;
final int midVal = array[mid]; if (midVal < value) {
lo = mid + ;
} else if (midVal > value) {
hi = mid - ;
} else {
return mid; // value found
}
}
return ~lo; // value not present
}
(2)四种删除数据的方法
--前两种
public void delete(int key)
public void remove(int key)
两者作用是相同的,没区别,因为remove()内部就直接调用了delete()
/**
* Alias for {@link #delete(int)}.
*/
public void remove(int key) {
delete(key);
}
--后两种
public void removeAt(int index)
public void clear()
一个是删除指定坐标的数据
一个是清空所有的数据
(3)两种修改数据的方法
public void setValueAt(int index, E value)
public void put(int key, E value)
这里put()方法可能会有疑惑,它不是添加数据的么,怎么也可以修改数据了?
看下put()部分源码:
int i = ContainerHelpers.binarySearch(mKeys, mSize, key); if (i >= ) {
mValues[i] = value;
} else {
先是查找这个key是不是存在,返回一个整型,如果i>=0,说明存在,直接修改值 ,否则执行else()添加数据
(4)查询获取数据的方法
--获取键对应的值
public E get(int key)
public E get(int key, E valueIfKeyNotFound)
很简单,获取某个键对应的值,两个参数的方法的第二个参数当然就是没有这个key键,返回的默认值
--根据坐标获取该位置的键
public int keyAt(int index)
--根据坐标获取该位置的值
public E valueAt(int index)
----------------------------------------------
--查看键所在的位置
public int indexOfKey(int key)
--查看值所在的位置
public int indexOfValue(E value)
这两个方法返回一个整型数值,往常来说,返回-1代表不存在。
但是这两个方法返回的值不确定,但查询不到的话返回的值还是一个负数。判断是否小于0即可
-------------------------------------------------------------------------------------------------------
相关知识:
SparseArray<E>详解的更多相关文章
- Android 之SparseArray<E>详解
SparseArray是android里为<Interger,Object>这样的Hashmap而专门写的class,目的是提高效率,其核心是折半查找函数(binarySearch) pr ...
- Android编程之SparseArray<E>详解
最近编程时,发现一个针对HashMap<Integer, E>的一个提示: 翻译过来就是:用SparseArray<E>来代替会有更好性能.那我们就来看看源码中SparseAr ...
- 详解ListView加载网络图片的优化,让你轻松掌握!
详解ListView加载网络图片的优化,让你轻松掌握! 写博客辛苦了,转载的朋友请标明出处哦,finddreams(http://blog.csdn.net/finddreams/article/de ...
- Android Telephony分析(三) ---- RILJ详解
前言 本文主要讲解RILJ工作原理,以便更好地分析代码,分析业务的流程.这里说的RILJ指的是RIL.java (frameworks\opt\telephony\src\java\com\andro ...
- 详解 CmProcess 跨进程通信的实现
CmProcess 是 Android 一个跨进程通信框架,整体代码比较简单,总共 20 多个类,能够很好的便于我们去了解跨进程实现的原理. 个人猜测 CmProcess 也是借鉴了 VirtualA ...
- Linq之旅:Linq入门详解(Linq to Objects)
示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...
- 架构设计:远程调用服务架构设计及zookeeper技术详解(下篇)
一.下篇开头的废话 终于开写下篇了,这也是我写远程调用框架的第三篇文章,前两篇都被博客园作为[编辑推荐]的文章,很兴奋哦,嘿嘿~~~~,本人是个很臭美的人,一定得要截图为证: 今天是2014年的第一天 ...
- EntityFramework Core 1.1 Add、Attach、Update、Remove方法如何高效使用详解
前言 我比较喜欢安静,大概和我喜欢研究和琢磨技术原因相关吧,刚好到了元旦节,这几天可以好好学习下EF Core,同时在项目当中用到EF Core,借此机会给予比较深入的理解,这里我们只讲解和EF 6. ...
- Java 字符串格式化详解
Java 字符串格式化详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 文中如有纰漏,欢迎大家留言指出. 在 Java 的 String 类中,可以使用 format() 方法 ...
随机推荐
- 蓝凌OA二次开发手册
1.蓝凌OA表单前端调用后台数据 一.后台存储过程: create procedure sp_test @ftext nvarchar(50) as begin select @ftext as '测 ...
- ArcGIS提取影像边界
基于ArcGIS有多重办法可以提取影像边界,比如常用的有以下几种方式: a.System Toolboxes --> 3D Analyst Tools --> Conversion --& ...
- DDD:整理了一些关于验证方面的文章
http://msdn.microsoft.com/en-us/library/ff664356(v=pandp.50).aspx http://gorodinski.com/blog/2012/05 ...
- [OpenCV] Image Processing - Image Elementary Knowledge
"没有坚实的理论基础,实践只会浅尝于表面." 这是两本打基础的书,没系统学过的话,怎么好意思说自己会CV. 该领域,兴军亮 这个名字屡次出现,看来是计算机视觉领域国内的年轻才俊,向 ...
- [转载]SharePoint 2013测试环境安装配置指南
软件版本 Windows Server 2012 标准版 SQL Server 2012 标准版 SharePoint Server 2013 企业版 Office Web Apps 2013 备注: ...
- [Node.js] Cluster,把多核用起来
原文地址: http://www.moye.me/?p=496 引子 众所周知,虽然Node的底层有一个IO线程池,但其应用层默认是单线程运行的,对于多核CPU环境来说,是一种资源的浪费. 所幸Nod ...
- SQL Server 2014,改善的临时表缓存
在一些先决条件下,SQL Server可以缓存临时表(cache Temp Tables).缓存临时表意味着当你创建反复创建同个临时表时,SQL Server就可以重用它们.这会从整体上大幅度提高你的 ...
- .net 根据匿名类生成实体类,根据datatable生成实体类,根据sql生成实体类
在开发中可能会遇到这几种情况 1.EF或LINQ查询出来的匿名对象在其它地方调用不方便,又懒的手动建实体类 2.通过datatable反射实体需要先建一个类 ,头痛 3.通过SQL语句返回的实体也需要 ...
- 外表cms,内在wiki的系统anwiki
比较完整面向对象的语法格式, 外表cms,内在wiki的系统 http://enanocms.org/features 比较老,php4的语法
- 我的HTML笔记
HTML(Hypertext Marked Language)"超文本标记语言". 1.HTML的声明 <!DOCTYPE html> 2.HTML的基本结构 < ...