sharedPerference 一般用来 1.配置数据,2.保存数据(一些我们上次点击选择的内容,我们希望在下次应用调起的时候依然有效,无须用户再一次进行配置或选择。Android提供preference这个键值对的方式来处理这种情况)。
1.sharedPerference 用来配置数据的时候我们一般这样获取
public abstractSharedPreferences getSharedPreferences (String name, int mode)方法得到一个sharedpreferences对象,参数name是preference文件的名字,mode则是方式,默认为0。这个方法是在context这个接口里面的一个抽象方法
具体的实现方法是:
//Context类静态数据集合,以键值对保存了所有读取该xml文件后所形成的数据集合
private static final HashMap<File, SharedPreferencesImpl> sSharedPrefs =
new HashMap<File, SharedPreferencesImpl>();
@Override
public SharedPreferences getSharedPreferences(String name, int mode){
//其所对应的SharedPreferencesImpl对象 ,该对象已一个HashMap集合保存了我们对该文件序列化结果
SharedPreferencesImpl sp;
File f = getSharedPrefsFile(name); //该包下是否存在对应的文件,不存在就新建一个
synchronized (sSharedPrefs) { //是否已经读取过该文件,是就直接返回该SharedPreferences对象
sp = sSharedPrefs.get(f);
if (sp != null && !sp.hasFileChanged()) {
//Log.i(TAG, "Returning existing prefs " + name + ": " + sp);
return sp;
}
}
//以下为序列化该xml文件,同时将数据写到map集合中
Map map = null;
if (f.exists() && f.canRead()) {
try {
str = new FileInputStream(f);
map = XmlUtils.readMapXml(str);
str.close();
}
...
}
synchronized (sSharedPrefs) {
if (sp != null) {
//Log.i(TAG, "Updating existing prefs " + name + " " + sp + ": " + map);
sp.replace(map); //更新数据集合
} else {
sp = sSharedPrefs.get(f);
if (sp == null) {
//新建一个SharedPreferencesImpl对象,并且设置其相关属性
sp = new SharedPreferencesImpl(f, mode, map);
sSharedPrefs.put(f, sp);
}
}
return sp;
}
}
我们获取数据的代码如下 是通过 SharedPreferences的实现类SharedPreferencesImpl来操作的
private static final class SharedPreferencesImpl implements SharedPreferences{
private Map mMap; //保存了该文件序列化结果后的操作, 键值对形式
//通过key值获取对应的value值
public String getString(String key, String defValue) {
synchronized (this) {
String v = (String)mMap.get(key);
return v != null ? v : defValue;
}
}
...
//获得该SharedPreferencesImpl对象对应的Edito类,对数据进行操作
public final class EditorImpl implements Editor {
private final Map<String, Object> mModified = Maps.newHashMap(); //保存了对键值变化的集合
}
}
然后是通过sharedpreferences的editor()方法得到editor对象,之后可以进行相应的编辑操作。
最后通过public abstractSharedPreferences.Editor putString (String key,String value)
执行commit()或是apply()方法,将会应用更改。具体代码如下:
Editor sharedata = getSharedPreferences("data", 0).edit();
sharedata.putString("item","hello getSharedPreferences");
sharedata.commit();
2.sharedPerference 用来保存数据的时候我们一般这样获取
PreferenceManager.getDefaultSharedPreferences(context);这个方法我们要传递一个context对象,
上下文对象我们一般是要操作哪个activity的上下文就穿哪个activity.this就可以了,至于为什么我们看一个UML图就知道了,具体如下:
然后操作数据是和上面一个首先就是获取一个sharedPerference对象然后获取editor然后就可以操作数据了
在具体的项目当中我们可以针对相应需求稍微进行封装,代码具体如下:
public class PreferenceModel {
private SharedPreferences prefs;
private Editor prefsEdit;
private static final PreferenceModel preferenceModel = new PreferenceModel();
private PreferenceModel() {
}
public static PreferenceModel instance(Context context) {
preferenceModel.prefs = PreferenceManager.getDefaultSharedPreferences(context);
return preferenceModel;
}
/**
* 得到所有的properties配置
*
* @return
*/
public Map<String, ?> getAllSystemProperties() {
return prefs.getAll();
}
/**
* 根据key得到properties配置
*/
public Object getSystemProperties(String key, Object defValue, Types type) {
Object curValue = null;
switch (type) {
case BOOLEAN:
curValue = prefs.getBoolean(key, (Boolean) defValue);
break;
case FLOAT:
curValue = prefs.getFloat(key, (Float) defValue);
break;
case INTEGER:
curValue = prefs.getInt(key, (Integer) defValue);
break;
case LONG:
curValue = prefs.getLong(key, (Long) defValue);
break;
case STRING:
curValue = prefs.getString(key, (String) defValue);
break;
}
return curValue;
}
/**
* 保存properties配置
*
* @param key
* @param value
* @param type
*/
public void saveSystemProperties(String key, Object value, Types type) {
if (prefsEdit == null) {
initPrefsEdit();
}
switch (type) {
case BOOLEAN:
prefsEdit.putBoolean(key, (Boolean) value);
break;
case FLOAT:
prefsEdit.putFloat(key, (Float) value);
break;
case INTEGER:
prefsEdit.putInt(key, (Integer) value);
break;
case LONG:
prefsEdit.putLong(key, (Long) value);
break;
case STRING:
prefsEdit.putString(key, (String) value);
break;
}
commitPrefsEdit();
}
/**
* 删除对应key的properties参数配置
*
* @param key
* @param value
*/
public void removeSystemProperties(String key) {
if (prefsEdit == null) {
initPrefsEdit();
}
prefsEdit.remove(key);
commitPrefsEdit();
}
/**
* 获得默认的SharedPreferences对象,此程序内部可读写(内部采用Properties文件形式保存数据)
*
* @return
*/
public SharedPreferences getDefaultSharedPreferences() {
return prefs;
}
/**
* 为减少创建开销,只有当需要保存参数的时候才初始化prefsEdit
*/
private synchronized void initPrefsEdit() {
if (prefsEdit == null) {
prefsEdit = prefs.edit();
}
}
/**
* 保存编辑提交
*/
private void commitPrefsEdit() {
if (prefsEdit != null) {
prefsEdit.commit();
}
}
}