Android之SharedPreferences詳解與原理分析
SharedPreferences作為Android儲存資料方式之一,主要特點是:
1. 只支援Java基本資料型別,不支援自定義資料型別;
2. 應用內資料共享;
3. 使用簡單.
使用方法
1、存資料
SharedPreferences sp = getSharedPreferences("sp_demo", Context.MODE_PRIVATE);
sp.edit().putString("name", "小張").putInt("age", 11).commit();
或者下面的寫法也可以
SharedPreferences sp = getSharedPreferences("sp_demo" , Context.MODE_PRIVATE);
Editor editor = sp.edit();
editor.putString("name", "小張");
editor.putInt("age", 11);
editor.commit();
切記不要寫成下面的形式,會導致資料無法儲存
SharedPreferences sp = getSharedPreferences("sp_demo", Context.MODE_PRIVATE);
sp.edit().putString("name", "小張");
sp.edit().putInt("age", 11);
sp.edit ().commit();
為什麼這種方式無法儲存,因為sp.edit()每次都會返回一個新的Editor物件,Editor的實現類EditorImpl裡面會有一個快取的Map,最後commit的時候先將快取裡面的Map寫入記憶體中的Map,然後將記憶體中的Map寫進XML檔案中。使用上面的方式commit,由於sp.edit()又重新返回了一個新的Editor物件,快取中的Map是空的,所以導致資料無法被儲存。
2、取資料
SharedPreferences sp = getSharedPreferences("sp_demo", Context.MODE_PRIVATE);
String name = sp.getString ("name", null);
int age = sp.getInt("age", 0);
getSharedPreferences的具體實現是在frameworks/base/core/java/android/app/ContextImpl.java,程式碼如下:
@Override
public SharedPreferences getSharedPreferences(String name, int mode) {
SharedPreferencesImpl sp;
synchronized (ContextImpl.class) {
......
final String packageName = getPackageName();
ArrayMap<String, SharedPreferencesImpl> packagePrefs = sSharedPrefs.get(packageName);
if (packagePrefs == null) {
packagePrefs = new ArrayMap<String, SharedPreferencesImpl>();
sSharedPrefs.put(packageName, packagePrefs);
}
......
sp = packagePrefs.get(name);
if (sp == null) {
File prefsFile = getSharedPrefsFile(name);
sp = new SharedPreferencesImpl(prefsFile, mode);
packagePrefs.put(name, sp);
return sp;
}
}
......
return sp;
}
SharedPreferencesImpl是SharedPreferences介面的具體實現類,一個name對應一個SharedPreferencesImpl,一個應用程式中根據name的不同會有多個SharedPreferencesImpl。
SharedPreferencesImpl的具體實現是在frameworks/base/core/java/android/app/SharedPreferencesImpl.java,我們可以通過getSharedPreferences獲得SharedPreferences的例項,當我們呼叫sp.getString等get方法取資料時,實際上是直接從記憶體中的Map裡面去取,get方法傳入的第一個引數正好是Map的key,第二個引數是當Map中沒有這個key對應值的時候,返回的預設值。