Android中SharedPreference的用法
SharedPreference是Android系统中轻量级存储数据的一种方式,操作简便快捷,它的本质是基于XML文件存储Key-Value键值对数据,适合存放程序状态的配置信息。1.SharedPreference简介
本文介绍了SharedPreference的概念与简单使用,同时介绍了可以作为设置界面的PreferenceActivity的使用。
详细代码:github.com/Baolvlv/LearnAndroid/tree/master/SharedPreference
SharedPreference,轻型储存,基于xml文件储key-value储存键值对,储存位置在data/data/<包名>/shared_prefs目录下,本身只能获取数据而不支持储存与修改,通过传回的editor修改
sharedPreference对象与SQLite数据库相比,免去了创建数据库,创建表,写sql语句等操作,但不支持条件查询,作为SQLite数据库的一种补充
可以储存的数据类型有:boolean,int,float,long,String
2.SharedPreference的读写操作 首先声明sharedPreference与它的editor对象,必须在onCreate函数中实例化
//声明的sharedPreference在onCreate的函数中通过getPreference()和eidt方法实例化
SharedPreferencespreferences;
//声明sharedPreference的editor
SharedPreferences.Editoreditor;
//获取当前Activity的sharedPreference,onCreate函数之前不能调用getPreference通过editor的putString方法设置键值对的值并commit到sharedPreference
preferences= getPreferences(Activity.MODE_PRIVATE);
//创建preference的editor对象
editor=preferences.edit();
editor.putString(KEY,et.getText().toString());通过sharedPreference的getString方法获取值,如果没有值,通过第二个参数设置初值
if(editor.commit()){
Toast.makeText(getApplicationContext(),"写入成功",Toast.LENGTH_SHORT)
.show();
}
//第二个参数为当前键不存在时,其默认的值3.PreferenceActivity的使用 手机的设置界面,即通过PreferenceActivity实现。分组为PreferenceCategory,Wi-Fi右侧的开关为CheckBoxPreference,每次设置都会被preference保存下来,setting数据的持久化.
String in =preferences.getString(KEY,"当前值不存在");
Toast.makeText(getApplicationContext(),in,Toast.LENGTH_SHORT)
.show();
PreferenceActivity不使用layout文件作为布局,使用专有的preference.xml文件
Res目录下新建xml文件夹,在xml文件夹中,新建preference.xml文件
以PreferenceScreen为根布局,PreferenceCategory为分组
http://schemas.android.com/apk/res/android">其中,每种Preference的title为标题,summary为简介,defaultValue为没有设置summary时的默认值
android:title="list title"
android:summary="list_summery"
android:defaultValue="https://www.it610.com/article/@string/app_name"
android:entries="@array/list_preference"
android:entryValues="@array/list_preference"
android:dialogTitle="list_dialog_title"/>
android:title="edit title"
android:defaultValue="https://www.it610.com/article/@string/app_name"
android:summary="edit_summery"/>
android:title="checkbox title"
android:defaultValue="https://www.it610.com/article/false"
android:summary="checkbox summery"/>
key为每种preference的唯一标记值,相当于layout中的id,在xml与java文件中必须一致
ListPreference中entries与entryValue配合,为弹出对话框的列表,需要设置为数组
在res/values下新建array.xml,作为对话框列表数组在作为设置界面的activity中实现ui
使当前Activity继承自PreferenceActivity。
由于PreferenceActivity继承自ListActivity,所以在onCreate()函数中,不能执行setContentView方法
在android3.0之前,在onCreate函数中执行addPreferenceFromResource加载xml文件,
并通过findPreference通过键值查找并实例化组件
addPreferencesFromResource(R.xml.preference);在android3.0之后,创建PreferenceFragment,将preferenceFragment加载到activity中
initPreference();
private voidinitPreference(){
lp= (ListPreference) findPreference(Keys.LIST_KEY);
etp= (EditTextPreference) findPreference(Keys.EDIT_KEY);
cp= (CheckBoxPreference) findPreference(Keys.CHECK_KEY);
}
实现OnSharedPreferenceChangeListener接口,复写onSharedPreferenceChanged方法,执行任何key对应的值改变的操作,通过sharedPreferences获取key所对应的值
implementsSharedPreferences.OnSharedPreferenceChangeListener {当重回Activity,activity恢复时,重设summery为上一次的值,并重新绑定Listener对象
//任何key的值改变时,更新Summery的值
@Override
public voidonSharedPreferenceChanged(SharedPreferences sharedPreferences,String key) {
if(key.equals(Keys.EDIT_KEY)){
etp.setSummary(sharedPreferences.getString(key,"text"));
}else if(key.equals(Keys.LIST_KEY)){
lp.setSummary(sharedPreferences.getString(key,""));
}
//Activity恢复时执行,用于刷新的操作当Activity停止时,解除listener绑定
@Override
protected voidonResume() {
super.onResume();
//设置summary的值
SharedPreferences sp = getPreferenceScreen().getSharedPreferences();
lp.setSummary(sp.getString(Keys.LIST_KEY,""));
etp.setSummary(sp.getString(Keys.EDIT_KEY,"text"));
//只要activity恢复时,重注册sharedPreferenceChangeListener
sp.registerOnSharedPreferenceChangeListener(this);
}
@Overridexml设置布局,addPreferenceFromResource添加,通过sharedPrefernences获取值
protected voidonPause() {
super.onPause();
//Activity停止时,解除Listener
getPreferenceScreen().getSharedPreferences()
.unregisterOnSharedPreferenceChangeListener(this);
}
如果使用PreferenceFragment,则新建类继承自PreferenceFragment,
重写onCreate函数,在onCreate函数中addPreferenceFromResource
public classMyPreferenceFragmentextendsPreferenceFragment{任何一个普通的Activity都可以加载PreferenceFragment
@Override
public voidonCreate(@NullableBundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.preference);
getFragmentManager().beginTransaction().replace(android.R.id.content,newMyPreferenceFragment())注意第一个参数为android.R.id.content(根布局)
.commit();
【Android中SharedPreference的用法】如果使用普通的Activity,不能实例化子Preference,即不能改变summery
推荐阅读
- 热闹中的孤独
- android第三方框架(五)ButterKnife
- Shell-Bash变量与运算符
- JS中的各种宽高度定义及其应用
- 2021-02-17|2021-02-17 小儿按摩膻中穴-舒缓咳嗽
- 深入理解Go之generate
- 异地恋中,逐渐适应一个人到底意味着什么()
- 我眼中的佛系经纪人
- 《魔法科高中的劣等生》第26卷(Invasion篇)发售
- “成长”读书社群招募