首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

ArrayMap vs HashMap

问:ArrayMap vs HashMap,要怎么选?...答:当size小于等于8的时候,选择ArrayMap,其他情况下选择hashmap ArrayMap的优势:更节约内存 内存增长慢:arraymap内存增加是每次增加1.5倍,而hashmap是每次增加...了,下面继续用自问自答的方式了解下arraymap 存储载体是什么 存储的载体,才是了解一个map的本质,ArrayMap的载体是两个数组,一个是存储Key的hash值,一个是存储key跟value...,另外,arraymap存在两个版本,一个是AndroidX,一个是系统framework //framework自带的arraymap android.util.ArrayMap //Androidx...的arraymap androidx.collection.ArrayMap 使用的时候,切记使用Androidx的arraymap,以保证在所有版本的系统上,表现一致

80420
您找到你想要的搜索结果了吗?
是的
没有找到

深度解读ArrayMap优势与缺陷

为此,2013年5月20日Google工程师Dianne Hackborn在Android系统源码中新增ArrayMap类。...在Android源码中可以发现不少提交专门把之前使用HashMap地方改用ArrayMap,不仅如此,大量的应用开发者中广为使用。 然后,你是否研究过这么广泛使用的基础数据结构存在缺陷?...要回答这个问题,需要先从源码角度来理解ArrayMap的原理,阅读时长约30分钟。 ArrayMap是Android专门针对内存优化而设计的,用于取代Java API中的HashMap数据结构。...HashMap的查找和插入时间复杂度为O(1)的代价是牺牲大量的内存来实现的,而SparseArray和ArrayMap性能略逊于HashMap,但更节省内存。 接下来,从源码看看ArrayMap。...4.3 ArraySet ArraySet也是Android特有的数据结构,用于替代HashSet的,跟ArrayMap出自同一个作者,从源码来看ArraySet跟ArrayMap几乎完全一致,包含缓存机制

1.8K20

源码分析多进程下的SharedPreferences

那么为什么会这样子呢,笔者带大家从源码的角度来分析一下,我们来看一下关于SharedPreferences的源码。...中是否存在该File对象,不存在则创建一个并放入ArrayMap,然后调用getSharedPreferences的重载方法getSharedPreferences(file, mode),我们看一下这个方法的源码...我们直接看一下SharedPreferencesImpl的源码,验证一下我们的猜想。...为什么在同个进程却又没有问题呢,或者其他线程对SharedPreferences的获取在值修改完毕之后也没有问题,这里我们看一下SharedPreferencesImpl的内部类EditorImpl的源码...中获取对应的File(无的话则创建ArrayMap或在ArrayMap中添加该键值对),然后调用重载方法getSharePreferences(File file,int mode)传入file,该方法中将通过包名从缓存中获取

36610

React-Native 安卓预加载优化方案

React-Native安卓预加载优化方案 为了优化React-Native安卓端线上业务的用户体验,我们提出了React-Native安卓Bundle预加载优化方案 首先展示的是React-Native安卓源码端...(Throwable e) { Logger.e(TAG, e); } } } 在init操作中,我们通过ReactInfo缓存把view缓存在本地的ArrayMap...同时为了优化React-Native线上项目内存方面的占用率,在ReactActivity销毁后,我们需要使用onDestroy()方法把view从 parent 上卸载下来 获取预加载之后缓存在本地ArrayMap...中的rootView 为了获取并使用预加载之后缓存在本地ArrayMap中的rootView,我们需要侵入activity的创建过程,因此我们需要对React-Native原生库库提供的ReactActivity...如下图所示: ReactPreLoader.init(this, ReactCardActivity.reactInfo); 其中ReactCardActivity继承上一个模块中对React-Native源码库进行简单改造后的

5.5K11

Android中传值Intent与Bundle的区别小结

然后看下intent的put方法源码: public @NonNull Intent putExtra(String name, Parcelable value) { if (mExtras =...Bundle内部是由ArrayMap实现的,ArrayMap的内部实现是两个数组,一个int数组是存储对象数据对应下标,一个对象数组保存key和value,内部使用二分法对key进行排序,所以在添加、删除...而HashMap内部则是数组+链表结构,所以在数据量较少的时候,HashMap的Entry Array比ArrayMap占用更多的内存。...因为使用Bundle的场景大多数为小数据量,我没见过在两个Activity之间传递10个以上数据的场景,所以相比之下,在这种情况下使用ArrayMap保存数据,在操作速度和内存占用上都具有优势,因此使用

1.5K20

Weekly 之 集合 专栏

: 数据结构 ArrayMap 和 SparseArray 采用的都是两个数组,Android专门针对内存优化而设计的 HashMap 采用的是数据+链表+红黑树 内存优化 ArrayMap 比 HashMap...更节省内存,综合性能方面在数据量不大的情况下,推荐使用 ArrayMap; Hash 需要创建一个额外对象来保存每一个放入 map 的 entry,且容量的利用率比 ArrayMap 低,整体更消耗内存...性能方面: ArrayMap 查找时间复杂度 O(logN);ArrayMap 增加、删除操作需要移动成员,速度相比较慢,对于个数小于 1000 的情况下,性能基本没有明显差异 HashMap 查找、修改的时间复杂度为...并发问题 ArrayMap 是非线程安全的类,大量方法中通过对 mSize 判断是否发生并发,来决定抛出异常。...这一点的处理比 ArrayMap 更有全面。

49030
领券