这是一篇你应该了解的Android数据存储优化

别说,还挺多,有DataStoreMMKV 和 数据库

一、介绍

====

上面说了四种本地数据存储方式,简单介绍一下吧。

1. SharedPreferences

=====================

这个应该就不用介绍了,大家的老朋友,用于存储偏好设置。

2. DataStore

=============

DataStore 也是 Android Jetpack 中的一员,它是谷歌爸爸用来取缔 SharedPreferences 的。

所以,简单来说,它的作用也是存储偏好设置,不过,除了键值对以外,这位大哥还支持类型化对象。

什么是类型化对象,就是存对象。

常见的场景就是读书读了一半,退出了,需要存储书Id、章节Id和进度,不存用户Id的情况,需要使用三个键值对,使用封装好的对象只需要一个类型。

不过,数据足够复杂或者多维度的时候请使用数据库

3. MMKV

========

腾讯出品,必属精品。

同上面几个一样,主要用来存储键值对,但性能非常出色,毕竟经过了微信客户端的验证。

4. SQLite

==========

跟上面哥几个的定位不太一样,主要用来对象的持久化存储。

比如,上面读书读一半的场景,举一个不太恰当的例子,你希望记录每个登陆用户对应的读书场景,这个时候,偏好设置肯定不太能满足你的需求,数据库就登场了。

二、测试

====

简单写了一段测试代码:

  1. 测试项目地址:https://github.com/mCyp/Hoo

  2. 测试过程:单个文件1000次的读写和查询

测试界面,路径【我的】-【数据存储】:

这是一篇你应该了解的Android数据存储优化

1. 写入结果

========

单文件1000次数据写入的情况:

这是一篇你应该了解的Android数据存储优化

看到这个结果的时候属实有点意外,Google 推出的 DataStore 怎么就最慢了?

1. SharedPreferences

=====================

SharedPreferences 的慢也在情理之中,主要有两点:

  • 数据写入进文件比较耗时。

  • 增量更新会导致数据重新写入。

特别是第二点,导致了最终 3300ms 的耗时。

2. MMKV

========

MMKV为什么这么快?主要有三点:

  • mmap:如果你了解过 Binder,你肯定知道它的快是因为内存映射,MMKV 也使用内存映射,App 只管往里写数据,最后由操作系统负责将内存回写到文件,并且不用担心 crash 导致的数据丢失。

  • 数据组织:使用 protobuf 进行数据序列化。

  • 写入优化:增量更新将 kv 对象加到内存末尾,操作这块内存的 Linux内核会自动将这部分数据写入到文件。

最终的时长是 17ms。

3. SQLite

==========

SQLite 对应的第三方库为 Android Jetpack 中的 Room,它的慢是因为:

  • 1000次的文件IO操作。

  • 存储对象要比键值对复杂,不过本项目中的对象只有两个字段。

总的而言,当 SharedPreferences 中单个文件存了很多键值对的时候,每次增量更新会导致内存中所有键值对的重新写入,而 SQLite 应该是仅需处理当前的对象,所以内存也会远远小于 SharedPreferences。

4. DataStore

=============

DataStore 的结果属实让所有人都意外。

DataStore,谷歌 Android Jetpack 中的新成员,protobuf 夹持,天之骄子,霍霍一顿操作,效率竟然还不如 SharedPreferences?

这说得过去吗?显然说不过去,我简单看了一下源码(有可能不太准确),大概有以下原因:

  • 每个 edit 操作都会开启一个子协程,1000次的 edit 操作的开销不容小觑。

  • 1000次文件IO操作。

  • 增量更新也会导致内存中的数据重新写入到文件。

因为多了一个开子协程的操作,所以直接导致了 10594ms 之久。

2. 读取结果

========

对之前的1000次写入的数据读取并进行检验:

这是一篇你应该了解的Android数据存储优化

可以看到,DataStore 仍然大于 SharedPreferences 和 MMKV。

1. SharedPreferences和MMKV

==========================

SharedPreferences 和 MMKV 分别是 14ms 和 12ms,测试中,有时 SharedPreferences 快,有时 MMKV 快,总的而言,两个结果差不多。

快的原因是两者都是直接从内存中读取。

2. SQLite

==========

这次 SQLite 变成最慢的了,耗时达 296ms,因为每次查询都要从数据库中查询。

总结

其实客户端开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

Android大厂面试真题全套解析

2017-2020字节跳动Android面试真题解析PDF
然而Android架构学习进阶是一条漫长而艰苦的道路,不能靠一时激情,更不是熬几天几夜就能学好的,必须养成平时努力学习的习惯。所以:贵在坚持!

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

[外链图片转存中…(img-UbfryRfg-1715417021106)]

[外链图片转存中…(img-V80XAoh5-1715417021107)]
然而Android架构学习进阶是一条漫长而艰苦的道路,不能靠一时激情,更不是熬几天几夜就能学好的,必须养成平时努力学习的习惯。所以:贵在坚持!

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值