返回列表 发新帖

android中数据存储_Android

[复制链接]

14

主题

30

帖子

30

积分

新手上路

Rank: 1

积分
30
发表于 2024-10-5 07:15:15  | 显示全部楼层 | 阅读模式
在Android中,数据存储主要通过SharedPreferences、文件存储、SQLite数据库和ContentProvider等方式实现。这些方法各有优缺点,适用于不同的应用场景。
在Android中,有多种方式可以存储数据,以下是一些常见的数据存储方法:

zbhjgehn3kj3gkf.jpg

zbhjgehn3kj3gkf.jpg


(图片来源网络,侵删)
1、SharedPreferences
SharedPreferences是一种轻量级的数据存储方式,适用于存储简单的键值对数据,它提供了一种跨进程共享数据的方式。
方法 描述
getSharedPreferences(String name, int mode) 获取一个SharedPreferences实例,name为文件名,mode为操作模式
Editor edit() 获取一个Editor实例,用于编辑SharedPreferences中的数据
putString(String key, String value) 将键值对数据存储到SharedPreferences中
getString(String key, String defValue) 根据键名获取对应的值,如果不存在则返回默认值
remove(String key) 移除指定键名的数据
commit() 提交修改,保存数据
apply() 提交修改,但不立即保存数据,在下次启动时自动保存

2、SQLite数据库
SQLite是一个轻量级的嵌入式数据库,适用于存储结构化数据,Android系统内置了对SQLite的支持。
方法 描述
openOrCreateDatabase(String name, int mode, SQLiteDatabase.CursorFactory factory) 打开或创建一个数据库实例,name为数据库名,mode为操作模式,factory为游标工厂
SQLiteDatabase query() 执行SQL查询语句,返回查询结果的游标
close() 关闭数据库连接
insert(String table, String nullColumnHack, ContentValues values) 向表中插入一条数据,table为表名,nullColumnHack为空列占位符,values为要插入的数据
update(String table, ContentValues values, String whereClause, String[] whereArgs) 更新表中的数据,table为表名,values为要更新的数据,whereClause为更新条件,whereArgs为条件参数
delete(String table, String whereClause, String[] whereArgs) 删除表中的数据,table为表名,whereClause为删除条件,whereArgs为条件参数

3、File存储
File存储是将数据直接存储到文件系统中,Android提供了多种方式来操作文件,如读写文本文件、图片等。
方法 描述
openFileOutput(String name, int mode) 以指定的模式在应用的内部存储空间创建或打开一个文件,name为文件名,mode为操作模式
openFileInput(String name) 以只读模式在应用的内部存储空间打开一个文件,name为文件名
writeBytes(String data) 将字节数组写入文件
readBytes() 读取文件中的所有字节并返回一个字节数组
delete() 删除文件

4、ContentProvider

zbhjhsyo1qcbnyj.jpg

zbhjhsyo1qcbnyj.jpg


(图片来源网络,侵删)
ContentProvider是一种在不同应用程序之间共享数据的机制,通过ContentProvider,可以将数据发布到其他应用程序中,也可以从其他应用程序中获取数据。
方法 描述
onCreate() ContentProvider创建时调用此方法,用于初始化数据表和URI映射关系
query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) 根据给定的URI查询数据,返回查询结果的游标
insert(Uri uri, ContentValues values) 向指定的URI插入一条数据,values为要插入的数据
update(Uri uri, ContentValues values, String where, String[] whereArgs) 根据给定的URI更新数据,values为要更新的数据,where为更新条件,whereArgs为条件参数
delete(Uri uri, String where, String[] whereArgs) 根据给定的URI删除数据,where为删除条件,whereArgs为条件参数


下面是一个关于Android中数据存储方法的介绍:
存储方式 描述 优点 缺点 使用场景
文件存储 将数据以文件的形式保存在设备的内部存储或外部存储(如SD卡) 简单易用,直接操作文件;不需要权限(内部存储) 文件安全性较低,数据容易泄露;读写速度较慢 保存不需要加密的文本、图片等文件
SharedPreference 以键值对的形式存储数据,通常用于存储应用的配置信息 操作简单,API易用;支持多种数据类型 数据量有限,不适合存储大量数据;数据存储在xml文件中,容易泄露 存储应用的简单配置信息,如用户偏好设置
SQLite数据库 Android内置的轻量级关系型数据库 数据结构化,便于管理;支持SQL查询,灵活高效 数据库操作相对复杂;不支持多线程操作 适用于存储结构化数据,如联系人、通话记录等
ContentValues 用于存储数据库中的数据,通常与SQLite数据库结合使用 简化数据库操作;支持多种数据类型 只能用于数据库操作 作为SQLite数据库的辅助类,存储表中的数据
Internal Storage 内部存储,不需要权限,适合存储私有数据 不需要权限,相对安全;数据在应用卸载时自动删除 存储空间有限;数据在应用卸载时会被删除 存储应用私有数据,如缓存、配置文件等
External Storage 外部存储,如SD卡,需要读取存储权限 存储空间大,可以保存大量数据;支持多种文件格式 需要申请权限;数据可能被其他应用访问或删除 保存用户生成的文件,如照片、视频等
ContentProvider 一种跨应用共享数据的方式,通常与SQLite数据库结合使用 支持跨应用数据共享;数据访问统一管理,安全性较高 实现复杂,性能相对较低;需要对数据进行封装 适用于需要跨应用共享数据的应用,如联系人、短信等
ROOM Android官方推出的数据库框架,基于SQLite,支持RxJava、LiveData等 支持RxJava、LiveData;支持编译时检查;性能较好 学习成本较高;相对较新,社区支持有限 适用于需要高性能、支持实时数据更新的大型应用

这个介绍简要介绍了Android中常用的数据存储方式,以及它们的优缺点和使用场景,根据实际需求,你可以选择适合的存储方式。

zbhjlf1rlhze0jf.png

zbhjlf1rlhze0jf.png


(图片来源网络,侵删)
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表