Android数据存储-文件存储-SharedPreferences
SharedPreferences是android官方提供的用来存储数据的一个框架(说框架可能有些大,或者可以说是一套API,一套工具类)。
SharedPreferences将数据以键值对的方式存储在data/data/应用包名/shared_prefs目录下的XML文件中。它是永久保留的,当用户卸载了应用后它也会随之删除。它是应用的私有的文件,其它应用一般是不能访问的。
下面从三个方面来介绍SharedPreferences:
适用场景
SharedPreferences适用于存储少量的适合以键值对方式保存的数据,它适用于存储程序逻辑产生的数据(例如存储用户角色信息)。
如果你想要保存一些用户的个人偏好的信息(用户首选项),android官方建议使用PreferenceActivity。
如何使用
(1)获取SharedPreferences对象
如果你想存储的数据是属于整个应用的,你将来可能在程序的任何地方访问它,那么你需要使用如下方式:
SharedPreferences sharedPref=context.getSharedPreferences(
context.getString(R.string.filename),Context.MODE_PRIVATE);
如果你只想要一个用于Activity的数据文件,那么你可以使用如下方式:
SharedPreferences sharedPref=
activity.getPreferences(Context.MODE_PRIVATE)
(2)写入数据
要想写入数据,需要通过SharedPreferences创建一个
SharedPreferences.Editor传递你想要写入的数据的key(键)和value(值)。然后调用commit()方法保存所做的更改。
SharedPreferences.Editor editor = sharedPreferences.edit();
editor.putString("key", "value");
editor.commit();
当然你可以存储的不只是String类型的数据,你可以存储int、boolean等很多类型,这里存String类型的只是一个例子。
(3)读取数据
读取数据相对于写入数据来说就更简单了,只需要调用SharedPreferences对象的诸如getString()和getInt()等方法,为您想要的值提供键即可。需要注意的是在键不存在的情况下我们最好能够提供默认的返回值,这个默认的返回值需要根据业务逻辑提供合适的值,不要统一的String类型就直接提供”“字符串,int类型的就提供0或者1之类的(int类型的至少可以考虑将0和1定义成有意义的常量,不要出现魔法数字)。
sharedPref.getString("key", "defValue");
一些细节
获取SharedPreferences对象时的第二个参数可以有四种类型:
Context.MODE_PRAVITE;——应用私有文件
Context.MULTI_PROCESS;——跨进程通信使用
Context.MODE_WORLD_READABLE;——其它应用可读
Context.MODE_WORLD_WRITEABLE;——其它应用可写
其中
Context.MODE_WORLD_READABLE;——其它应用可读
Context.MODE_WORLD_WRITEABLE;——其它应用可写
从API17(Android4.2)之后已经被弃用(deprecated),Android N(7.0)以后如果再使用就会抛出一个SecurityException。
Context.MULTI_PROCESS;——跨进程通信使用
从API23(Android6.0)之后已经被弃用(deprecated),android官方认为在某些android的版本中它是不可信赖的。
官方不推荐使用SharedPreferences进行跨进程间数据通讯,如果要想跨进程数据通讯,建议使用ContentProvide。
所以现在在SharedPreference中的mode也就剩下Context.MODE_PRAVITE可用。
我们经常会在项目中对SharedPreference进行封装成一个工具类,这时就可以写定为Context.PRIVATE,不用让工具类的使用者再传递具体的mode了。
参考:
https://developer.android.google.cn/training/basics/data-storage/shared-preferences.html
https://developer.android.google.cn/guide/topics/data/data-storage.html