(转)Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (三) —— SharePreferences
除了SQLite数据库外,SharedPreferences也是一种轻型的数据存储方式,它的本质是基于XML文件存储key-value键值对数据,通常用来存储一些简单的配置信息。其存储位置在/data/data/<包名>/shared_prefs目录下。SharedPreferences对象本身只能获取数据而不支持存储和修改,存储修改是通过Editor对象实现。实现SharedPreferences存储的步骤如下:
一、根据Context获取SharedPreferences对象
二、利用edit()方法获取Editor对象。
三、通过Editor对象存储key-value键值对数据。
四、通过commit()方法提交数据。
具体实现代码如下:
1 publicclass MainActivity extends Activity {
2 @Override
3 publicvoid onCreate(Bundle savedInstanceState) {
4 super.onCreate(savedInstanceState);
5 setContentView(R.layout.main);
6
7 //获取SharedPreferences对象
8 Context ctx = MainActivity.this;
9 SharedPreferences sp = ctx.getSharedPreferences("SP", MODE_PRIVATE);
10 //存入数据
11 Editor editor = sp.edit();
12 editor.putString("STRING_KEY", "string");
13 editor.putInt("INT_KEY", 0);
14 editor.putBoolean("BOOLEAN_KEY", true);
15 editor.commit();
16
17 //返回STRING_KEY的值
18 Log.d("SP", sp.getString("STRING_KEY", "none"));
19 //如果NOT_EXIST不存在,则返回值为"none"
20 Log.d("SP", sp.getString("NOT_EXIST", "none"));
21 }
22 }
这段代码执行过后,即在/data/data/com.test/shared_prefs目录下生成了一个SP.xml文件,一个应用可以创建多个这样的xml文件。如图所示:
SP.xml文件的具体内容如下:
1 <?xml version='1.0' encoding='utf-8' standalone='yes' ?>
2 <map>
3 <string name="STRING_KEY">string</string>
4 <int name="INT_KEY" value="0"/>
5 <boolean name="BOOLEAN_KEY" value="true"/>
6 </map>
在程序代码中,通过getXXX方法,可以方便的获得对应Key的Value值,如果key值错误或者此key无对应value值,SharedPreferences提供了一个赋予默认值的机会,以此保证程序的健壮性。如下图运行结果中因为并无值为"NOT_EXIST"的Key,所以Log打印出的是其默认值:“none”。在访问一个不存在key值这个过程中,并无任何异常抛出。
SharedPreferences对象与SQLite数据库相比,免去了创建数据库,创建表,写SQL语句等诸多操作,相对而言更加方便,简洁。但是SharedPreferences也有其自身缺陷,比如其职能存储boolean,int,float,long和String五种简单的数据类型,比如其无法进行条件查询等。所以不论SharedPreferences的数据存储操作是如何简单,它也只能是存储方式的一种补充,而无法完全替代如SQLite数据库这样的其他数据存储方式。
相关链接:
Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (一)——总览
Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (二)——SQLite
Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (四) —— ContentProvider
相关文章
- [Android] SQLite数据库之增删改查基础操作
- Android学习---SQLite数据库的增删改查和事务(transaction)调用
- Android开发学习---使用Intelij idea 13.1 进行android 开发
- android 对sqlite数据库的增删改查等各种操作
- Delphi XE之路(8)xe5 android 手机上使用sqlite
- Android学习---数据库的增删改查(sqlite CRUD)
- android系统开发环境配置
- 【Android笔记31】Android中数据存储之SQLite数据库(Cursor、execSQL、rawQuery)
- Android源码中com.android.support依赖迁移到AndroidX库
- Android kotlin 从入门到进阶系列讲解(入门篇)SQLite数据库存储
- Android 拷贝SQLite数据库文件到手机的内部存储
- 在Android上使用qemu-user运行可执行文件
- android 11.0 12.0Launcher3去掉默认的google搜索栏
- Android 12.0 屏蔽FallbackHome机制去掉android正在启动直接进入默认Launcher功能实现
- 【Android Gradle 插件】Android 依赖管理 ② ( 为工程配置依赖仓库 | 为工程构建添加依赖仓库 | classpath 引入依赖库 | 配置依赖仓库 )
- 【Android Gradle 插件】ProductFlavor 配置 ( ProductFlavor#externalNativeBuild配置 | cmake 配置 | ndkBuild 配置 )
- 【Android 安全】DEX 加密 ( 代理 Application 开发 | 解压 apk 文件 | 判定是否是第一次启动 | 递归删除文件操作 | 解压 Zip 文件操作 )
- ANDROID 开发,安装离线安装包的下载地址及安装方法。
- Android的Bitmap和BitmapDrawable类解析-android学习之旅(六十)
- Android JNI环境要SQLite加密模块简介
- android sqlite批量插入数据速度解决方案
- Android数据存储——SQLite数据库(模板)
- ImageView的android:scaleType各属性含义(zz)
- android studio命令行更新sdk
- Android 自定义的验证码输入框(无光标),android版本10暂时不支持自定义粘贴
- Android 11.0 设置默认DNS