news 2026/1/9 16:56:01

【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/1/6 19:50:07

PaddlePaddle镜像如何实现在线学习(Online Learning)?

PaddlePaddle镜像如何实现在线学习&#xff08;Online Learning&#xff09;&#xff1f; 在推荐系统、广告投放和实时风控等业务场景中&#xff0c;用户行为数据每时每刻都在产生。如果模型仍然依赖每天甚至每周一次的离线批量训练&#xff0c;那它看到的永远是“昨天的世界”…

作者头像 李华
网站建设 2026/1/6 19:50:05

Screen Translator终极教程:三步实现屏幕文字智能翻译

Screen Translator终极教程&#xff1a;三步实现屏幕文字智能翻译 【免费下载链接】ScreenTranslator Screen capture, OCR and translation tool. 项目地址: https://gitcode.com/gh_mirrors/sc/ScreenTranslator Screen Translator是一款专业的屏幕捕获、OCR识别和智能…

作者头像 李华
网站建设 2026/1/6 19:50:03

iOS微信自动抢红包插件完整配置手册:从入门到精通

iOS微信自动抢红包插件完整配置手册&#xff1a;从入门到精通 【免费下载链接】WeChatRedEnvelopesHelper iOS版微信抢红包插件,支持后台抢红包 项目地址: https://gitcode.com/gh_mirrors/we/WeChatRedEnvelopesHelper 在移动社交日益普及的今天&#xff0c;微信红包已…

作者头像 李华
网站建设 2026/1/6 13:12:49

XUnity自动翻译器终极指南:轻松实现游戏本地化

XUnity自动翻译器终极指南&#xff1a;轻松实现游戏本地化 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 还在为外语游戏中的复杂对话和菜单而头疼吗&#xff1f;XUnity自动翻译器就是你的完美解决方案&…

作者头像 李华
网站建设 2026/1/9 7:55:13

如何快速获取百度网盘提取码:智能工具的完整指南

如何快速获取百度网盘提取码&#xff1a;智能工具的完整指南 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 还在为百度网盘分享链接的提取码而反复搜索吗&#xff1f;每次看到"请输入提取码"的提示&#xff0c;都让…

作者头像 李华