Android NDK开发详解应用数据和文件之数据和文件存储概览

本文详细介绍了Android应用中数据和文件的存储选项,包括应用专属、共享、偏好设置、数据库等,并讨论了不同存储位置的类别、权限需求以及分区存储在Android10及以上版本中的作用。还提供了检查设备文件的方法和相关资源链接。
摘要由CSDN通过智能技术生成

Android 使用的文件系统类似于其他平台上基于磁盘的文件系统。该系统为您提供了以下几种保存应用数据的选项:

应用专属存储空间:存储仅供应用使用的文件,可以存储到内部存储卷中的专属目录或外部存储空间中的其他专属目录。使用内部存储空间中的目录保存其他应用不应访问的敏感信息。
共享存储:存储您的应用打算与其他应用共享的文件,包括媒体、文档和其他文件。
偏好设置:以键值对形式存储私有原始数据。
数据库:使用 Room 持久性库将结构化数据存储在专用数据库中。

下表汇总了这些选项的特点:
在这里插入图片描述

您应根据自己的具体需求选择解决方案:

您的数据需要占用多少空间?
内部存储空间中用于存储应用专属数据的空间有限。如果您需要保存大量数据,请使用其他类型的存储空间。
数据访问需要达到怎样的可靠程度?
如果应用的基本功能需要某些数据(例如应用启动时需要的数据),可以将相应数据存放到内部存储目录或数据库中。存储在外部存储空间中的应用专属文件并非一直可以访问,因为有些设备允许用户移除提供外部存储空间的实体设备。
您需要存储哪类数据?
如果数据仅供您的应用使用,应使用应用专属存储空间。对于可分享的媒体内容,应使用共享的存储空间,以便其他应用可以访问相应内容。对于结构化数据,应使用偏好设置(适合键值对数据)或数据库(适合包含 2 个以上列的数据)。
数据是否应仅供您的应用使用?
在存储敏感数据(不可通过任何其他应用访问的数据)时,应使用内部存储空间、偏好设置或数据库。内部存储空间的一个额外优势是用户无法看到相应数据。

存储位置的类别

Android 提供两类物理存储位置:内部存储空间和外部存储空间。在大多数设备上,内部存储空间小于外部存储空间。不过,所有设备上的内部存储空间都是始终可用的,因此在存储应用所依赖的数据时更为可靠。

可移除卷(例如 SD 卡)在文件系统中属于外部存储空间。Android 使用路径(例如 /sdcard)表示这些存储设备。
注意:可用于保存文件的确切位置可能因设备而异。因此,请勿使用硬编码的文件路径。

默认情况下,应用本身存储在内部存储空间中。不过,如果您的 APK 非常大,也可以在应用的清单文件中指明偏好设置,以便将应用安装到外部存储空间:

<manifest ...
  android:installLocation="preferExternal">
  ...
</manifest>

对外部存储空间的访问和所需权限

Android 定义了以下与存储相关的权限:READ_EXTERNAL_STORAGE、WRITE_EXTERNAL_STORAGE 和 MANAGE_EXTERNAL_STORAGE。

在较低版本的 Android 系统中,应用需要声明 READ_EXTERNAL_STORAGE 权限才能访问位于外部存储空间中应用专属目录之外的任何文件。此外,应用需要声明 WRITE_EXTERNAL_STORAGE 权限才能向应用专属目录以外的任何文件写入数据。

Android 系统的版本越新,就越依赖于文件的用途而不是位置来确定应用对特定文件的访问和写入能力。特别是,如果您的应用以 Android 11(API 级别 30)或更高版本为目标平台,WRITE_EXTERNAL_STORAGE 权限完全不会影响应用对存储的访问权限。这种基于用途的存储模型可增强用户隐私保护,因为应用只能访问其在设备文件系统中实际使用的区域。

Android 11 引入了 MANAGE_EXTERNAL_STORAGE 权限,该权限提供对应用专属目录和 MediaStore 之外文件的写入权限。如需详细了解此权限,以及为何大多数应用无需声明此权限即可实现其用例,请参阅有关如何管理存储设备上所有文件的指南。

分区存储

为了让用户更好地管理自己的文件并减少混乱,以 Android 10(API 级别 29)及更高版本为目标平台的应用在默认情况下被授予了对外部存储空间的分区访问权限(即分区存储)。此类应用只能访问外部存储空间上的应用专属目录,以及本应用所创建的特定类型的媒体文件。
注意:如果您的应用在运行时请求与存储空间相关的权限,面向用户的对话框会表明您的应用正在请求对外部存储空间的广泛访问,即使已启用分区存储也是如此。

除非您的应用需要访问存储在应用专属目录和 MediaStore API 可以访问的目录之外的文件,否则请使用分区存储。如果您将应用专属文件存储在外部存储空间中,则可以将这些文件存放在外部存储空间中的应用专属目录内,以便更加轻松地采用分区存储。这样,在启用分区存储后,您的应用将可以继续访问这些文件。

如需让您的应用适合分区存储,请参阅存储用例和最佳实践指南。如果您的应用有其他用例未包含在分区存储范围内,请提交功能请求。您可以暂时选择停用分区存储。

查看设备上的文件

您可以使用 Android Studio 的设备文件浏览器查看存储在设备上的文件。

其他资源

如需详细了解数据存储,请参阅以下资源。

视频

为采用分区存储做好准备(2019 年 Android 开发者峰会)

本页面上的内容和代码示例受内容许可部分所述许可的限制。Java 和 OpenJDK 是 Oracle 和/或其关联公司的注册商标。

最后更新时间 (UTC):2023-03-30。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

五一编程

程序之路有我与你同行

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值