news 2026/6/10 10:53:13

【Android 数据】使用 JSON DataStore 实现自定义数据类的持久化存储

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Android 数据】使用 JSON DataStore 实现自定义数据类的持久化存储

一、DataStore 简介

  • Jetpack DataStore 是一种数据存储解决方案,让您可以使用协议缓冲区存储键值对或类型化对象。DataStore使用 Kotlin 协程和 Flow 以异步、一致的事务方式存储数据
  • 使用Preferences DataStore 实现键存储和访问数据。该实现不需要预定义的架构,并且不提供类型安全。它具有类似于 SharedPreferences 的 API,但没有与共享偏好设置相关的缺点。
  • 使用DataStore 可以持久保留自定义类。该实现必须为数据定义架构,并提供 Serializer 以将其转换为可持久保存的格式。可以选择使用 Protocol Buffers、JSON 或任何其他序列化策略。

二、DataStore 使用

1、添加依赖库

  • 使用 JSON 序列化,在 build.gradle.kt 中添加 Kotlin Serialization 依赖库。
  • 添加 DataStore 依赖库。
plugins{kotlin("android")version"2.0.21"kotlin("plugin.serialization")version"2.0.21"}dependencies{// JSON 序列化implementation("org.jetbrains.kotlinx:kotlinx-serialization-json:1.7.3")// DataStore(Proto or JSON)implementation("androidx.datastore:datastore:1.2.0")}

2、定义数据类

  • 定义需要持久保存的数据类,添加 @Serialization 注释进行序列化。
  • 定义一个实现 Serializer 的类,其中 T 是添加注解的数据类的类型。请务必为该序列化器添加默认值,以便在尚未创建任何文件时使用。
  • DataStore 的泛型类型必须不可变。更改 DataStore 中使用的类型会导致 DataStore 提供的一致性失效,并且可能会造成严重的、难以发现的 bug。
packagecom.android.datastore.datastore.jsonimportandroidx.datastore.core.CorruptionExceptionimportandroidx.datastore.core.Serializerimportkotlinx.coroutines.Dispatchersimportkotlinx.coroutines.withContextimportkotlinx.serialization.Serializableimportkotlinx.serialization.SerializationExceptionimportkotlinx.serialization.encodeToStringimportkotlinx.serialization.json.Jsonimportjava.io.InputStreamimportjava.io.OutputStream@SerializabledataclassSettings(valname:String,valnumber:Int,valisBoy:Boolean,valscore:Int)/** * 自定义序列化器 */objectSettingsSerializer:Serializer<Settings>{overridevaldefaultValue=Settings("Lin",1,false,60)overridesuspendfunreadFrom(input:InputStream):Settings{try{returnJson.decodeFromString<Settings>(input.readBytes().decodeToString())}catch(exception:SerializationException){throwCorruptionException("Unable to read Settings",exception)}}overridesuspendfunwriteTo(t:Settings,output:OutputStream){withContext(Dispatchers.IO){output.write(Json.encodeToString(t).encodeToByteArray())}}}

3、创建 DataStore

  • 使用 dataStore 所创建的属性委托来创建DataStore 实例,其中 T 是可序列化的数据类。
  • 请勿在同一进程中为给定文件创建多个 DataStore 实例,否则会破坏所有 DataStore 功能。如果给定文件在同一进程中有多个有效的 DataStore 实例,DataStore 在读取或更新数据时将抛出 IllegalStateException。
  • fileName 参数会告知 DataStore 使用哪个文件存储数据,文件存储路为:/data/data/<包名>/files/datastore/ 目录下
  • serializer 参数会告知 DataStore 在数据定义时的序列化器类的名称。
  • 使用DataStore.data显示所存储对象中相应属性的 Flow。
  • DataStore 提供了一个updateData() 函数,用于以事务方式更新存储的对象。updateData 为您提供数据的当前状态,作为数据类型的一个实例,并在原子读-写-修改操作中以事务方式更新数据。updateData 代码块中的所有代码均被视为单个事务。
  • 使用DataStore.data.first()进行首次加载数据。
packagecom.android.datastore.datastore.jsonimportandroid.content.Contextimportandroid
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 13:06:38

Windows任务栏透明化改造:让你的桌面焕发新生

Windows任务栏透明化改造&#xff1a;让你的桌面焕发新生 【免费下载链接】TranslucentTB 项目地址: https://gitcode.com/gh_mirrors/tra/TranslucentTB 想让Windows桌面摆脱千篇一律的单调外观&#xff1f;TranslucentTB这款轻量级工具正是你需要的桌面美化神器。它能…

作者头像 李华
网站建设 2026/6/9 23:21:21

PaddlePaddle镜像能否对接Redis缓存推理结果?

PaddlePaddle镜像能否对接Redis缓存推理结果&#xff1f; 在当前AI服务日益追求低延迟、高并发的背景下&#xff0c;一个看似简单却极具工程价值的问题浮现出来&#xff1a;当我们在容器中部署PaddlePaddle模型时&#xff0c;能不能把那些“算过一次”的结果记下来&#xff0c;…

作者头像 李华
网站建设 2026/6/10 13:06:03

xnbcli:星露谷物语XNB文件处理利器

xnbcli&#xff1a;星露谷物语XNB文件处理利器 【免费下载链接】xnbcli A CLI tool for XNB packing/unpacking purpose built for Stardew Valley. 项目地址: https://gitcode.com/gh_mirrors/xn/xnbcli xnbcli是一款专为《星露谷物语》游戏设计的命令行工具&#xff0…

作者头像 李华
网站建设 2026/6/10 13:11:27

Windows右键菜单管理终极指南:快速检测与修复冲突问题

Windows右键菜单管理终极指南&#xff1a;快速检测与修复冲突问题 【免费下载链接】ContextMenuManager &#x1f5b1;️ 纯粹的Windows右键菜单管理程序 项目地址: https://gitcode.com/gh_mirrors/co/ContextMenuManager 右键菜单问题困扰&#xff1f;立即掌握专业解决…

作者头像 李华
网站建设 2026/6/10 15:46:40

【拯救HMI】工业HMI通讯协议进阶:OPC UA协议的核心优势与应用

工业HMI通讯协议进阶&#xff1a;OPC UA协议的核心优势与应用当自动化系统从单机走向产线&#xff0c;从车间走向集团&#xff0c;Modbus这类传统协议在数据复杂性、安全性和互操作性上的局限便显现出来。OPC UA&#xff08;开放平台通信统一架构&#xff09;应运而生&#xff…

作者头像 李华
网站建设 2026/6/10 19:02:10

百度网盘提取码自动获取工具:告别手动搜索的终极解决方案

百度网盘提取码自动获取工具&#xff1a;告别手动搜索的终极解决方案 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 还在为百度网盘分享链接的提取码而烦恼吗&#xff1f;每次看到"请输入提取码"的提示框&#xff…

作者头像 李华