SharePreference类似于JavaEE中的session
SharedPreference主要是保存一些常用的配置比如窗口状态,一般在Activity中 重载窗口状态onSaveInstanceState保存一般使用SharedPreferences完成。 类似过去Windows系统上的ini配置文件,但是它分为多种权限,可以全局共享访问。
例子:
工程1:
- SharedPreferences shp=getSharedPreferences(SharePreference_name, Context.MODE_WORLD_READABLE);
- SharedPreferences.Editor editor = shp.edit();
- editor.putInt("storedInt", 100); // value to store
- editor.commit();
SharedPreferences shp=getSharedPreferences(SharePreference_name, Context.MODE_WORLD_READABLE); SharedPreferences.Editor editor = shp.edit(); editor.putInt("storedInt", 100); // value to store editor.commit();
工程2:
- Context mOtherContex;
- int storedPreference;
- try {
- mOtherContex = this.createPackageContext("com.android.testsharepreference", Context.CONTEXT_IGNORE_SECURITY);
- SharedPreferences preferences = mOtherContex.getSharedPreferences(SharePreference_name,MODE_WORLD_READABLE);
- storedPreference = preferences.getInt("storedInt", 0);
- } catch (NameNotFoundException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- storedPreference=200;
- }
Context mOtherContex; int storedPreference; try { mOtherContex = this.createPackageContext("com.android.testsharepreference", Context.CONTEXT_IGNORE_SECURITY); SharedPreferences preferences = mOtherContex.getSharedPreferences(SharePreference_name,MODE_WORLD_READABLE); storedPreference = preferences.getInt("storedInt", 0); } catch (NameNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); storedPreference=200; }
解说:工程1创建getSharedPreferences(SharePreference_name, Context.MODE_WORLD_READABLE);第二个参数就可以决定你的SharePreference要不要共享,有三种模式:MODE_PRIVATE ,MODE_WORLD_READABLE, MODE_WORLD_WRITEABLE;工程2 getSharedPreferences是通过工程1的Context来获得工程1的SharedPreference的实例。
========================================================
- <SPAN style="FONT-SIZE: medium">SharedPreferences getPreferences(int mode) 通过Activity可以返回一个SharedPrefenences的实</SPAN>例
SharedPreferences getPreferences(int mode) 通过Activity可以返回一个SharedPrefenences的实例
- <SPAN style="FONT-SIZE: medium">在Context下有这个方法 根据文件名称和mode来实例化SharedPreferences对象
- abstract SharedPreferences
- getSharedPreferences(String name, int mode)
- Retrieve and hold the contents of the preferences file 'name', returning a SharedPreferences through which you can retrieve and modify its values.
- </SPAN>
在Context下有这个方法 根据文件名称和mode来实例化SharedPreferences对象
abstract SharedPreferences
getSharedPreferences(String name, int mode)
Retrieve and hold the contents of the preferences file 'name', returning a SharedPreferences through which you can retrieve and modify its values.
- <SPAN style="FONT-SIZE: small"><STRONG>public interface
- SharedPreferences
- <!-- end header -->
- android.content.SharedPreferences
- Class Overview
- Interface for accessing and modifying preference data returned by getSharedPreferences(String, int) . For any particular set of preferences, there is a single instance of this class that all clients share. Modifications to the preferences must go through an SharedPreferences.Editor object to ensure the preference values remain in a consistent state and control when they are committed to storage.
- Note: currently this class does not support use across multiple processes. This will be added later.
- See Also</STRONG></SPAN>
- <SPAN style="FONT-SIZE: small"> * getSharedPreferences(String, int)
- SharedPreferences是一个接口,如果想添加和修改Preference data,就要通过getSharedPreferences(String,int)。在一个类里面实例化,就可以在其它地方共享这些数据。
- 目前这个类不支持多进程使用。
- <!-- jd-descr -->
- Summary
- <!-- ======== NESTED CLASS SUMMARY ======== -->
- </SPAN>
- <SPAN style="FONT-SIZE: medium"><STRONG>Nested Classes
- 这两个接口是SharedPreferences的内部类
- interface SharedPreferences.Editor SharedPreferences编辑器
- interface SharedPreferences.OnSharedPreferenceChangeListener 当数据改变的时候调用
- <!-- ========== METHOD SUMMARY =========== -->
- Public Methods
- abstract boolean contains (String key) 数据库里是否包含key的键值
- abstract SharedPreferences.Editor edit () 通过这个方法返回一个SharedPrefenences.Editor实例化对象
- abstract Map <String , ?> getAll () 返回所有的键值对,注意“?”,它代表你存储的数字类型,是泛型的用法
- abstract boolean getBoolean (String key, boolean defValue) 通过key从Preferences获取boolean类型的数据
- abstract float getFloat (String key, float defValue) 通过key从Preferences获取float类型的数据
- abstract int getInt (String key, int defValue) 通过key从Preferences获取int类型的数据
- abstract long getLong (String key, long defValue) 通过key从Preferences获取long类型的数据
- abstract String getString (String key, String defValue) 通过key从Preferences获取String类型的数据
- abstract void registerOnSharedPreferenceChangeListener (SharedPreferences.OnSharedPreferenceChangeListener listener)
- 注册一个监听器。当preferences数据改变的时候调用这个监听器下的方法
- abstract void unregisterOnSharedPreferenceChangeListener (SharedPreferences.OnSharedPreferenceChangeListener listener)
- 注册一个监听器。取消先前注册的回调方法。</STRONG></SPAN>
- <SPAN style="FONT-SIZE: medium">通过上面的editor() 方法就可以实例化SharedPreferences.Editor对象,接着就可以使用下面的一些方法进行存储。
- </SPAN>
- <SPAN style="FONT-SIZE: medium"><STRONG>Public Methods
- abstract SharedPreferences.Editor
- abstract boolean clear () 删除所有值
- commit () 提交你设置的值
- abstract SharedPreferences.Editor putBoolean (String key, boolean value) 设置boolean值存储
- abstract SharedPreferences.Editor putFloat (String key, float value) 设置浮点型数据存储
- abstract SharedPreferences.Editor putInt (String key, int value) 设置整形数据存储
- abstract SharedPreferences.Editor putLong (String key, long value) 设置长整型
- abstract SharedPreferences.Editor putString (String key, String value) 设置字符串数据存储
- abstract SharedPreferences.Editor
- remove (String key) 删除一个</STRONG></SPAN>
public interface SharedPreferences <!-- end header --> android.content.SharedPreferences Class Overview Interface for accessing and modifying preference data returned by getSharedPreferences(String, int) . For any particular set of preferences, there is a single instance of this class that all clients share. Modifications to the preferences must go through an SharedPreferences.Editor object to ensure the preference values remain in a consistent state and control when they are committed to storage. Note: currently this class does not support use across multiple processes. This will be added later. See Also * getSharedPreferences(String, int) SharedPreferences是一个接口,如果想添加和修改Preference data,就要通过getSharedPreferences(String,int)。在一个类里面实例化,就可以在其它地方共享这些数据。 目前这个类不支持多进程使用。 <!-- jd-descr --> Summary <!-- ======== NESTED CLASS SUMMARY ======== --> Nested Classes 这两个接口是SharedPreferences的内部类 interface SharedPreferences.Editor SharedPreferences编辑器 interface SharedPreferences.OnSharedPreferenceChangeListener 当数据改变的时候调用 <!-- ========== METHOD SUMMARY =========== --> Public Methods abstract boolean contains (String key) 数据库里是否包含key的键值 abstract SharedPreferences.Editor edit () 通过这个方法返回一个SharedPrefenences.Editor实例化对象 abstract Map <String , ?> getAll () 返回所有的键值对,注意“?”,它代表你存储的数字类型,是泛型的用法 abstract boolean getBoolean (String key, boolean defValue) 通过key从Preferences获取boolean类型的数据 abstract float getFloat (String key, float defValue) 通过key从Preferences获取float类型的数据 abstract int getInt (String key, int defValue) 通过key从Preferences获取int类型的数据 abstract long getLong (String key, long defValue) 通过key从Preferences获取long类型的数据 abstract String getString (String key, String defValue) 通过key从Preferences获取String类型的数据 abstract void registerOnSharedPreferenceChangeListener (SharedPreferences.OnSharedPreferenceChangeListener listener) 注册一个监听器。当preferences数据改变的时候调用这个监听器下的方法 abstract void unregisterOnSharedPreferenceChangeListener (SharedPreferences.OnSharedPreferenceChangeListener listener) 注册一个监听器。取消先前注册的回调方法。 通过上面的editor() 方法就可以实例化SharedPreferences.Editor对象,接着就可以使用下面的一些方法进行存储。 Public Methods abstract SharedPreferences.Editor abstract boolean clear () 删除所有值 commit () 提交你设置的值 abstract SharedPreferences.Editor putBoolean (String key, boolean value) 设置boolean值存储 abstract SharedPreferences.Editor putFloat (String key, float value) 设置浮点型数据存储 abstract SharedPreferences.Editor putInt (String key, int value) 设置整形数据存储 abstract SharedPreferences.Editor putLong (String key, long value) 设置长整型 abstract SharedPreferences.Editor putString (String key, String value) 设置字符串数据存储 abstract SharedPreferences.Editor remove (String key) 删除一个
SharedPreferences存储类效率分析
SharedPreferences是Android平台上一个轻量级的存储类,主要是保存一些常用的配置比如窗口状态,一般在Activity中重载窗口状态onSaveInstanceState保存一般使用SharedPreferences完成,它提供了Android平台常规的Long长整形、Int整形、String字符串型的保存,它是什么样的处理方式呢?
SharedPreferences类似过去Windows系统上的ini配置文件,但是它分为多种权限,可以全局共享访问,android123提示最终是以xml方式来保存,整体效率来看不是特别的高,对于常规的轻量级而言比SQLite要好不少,如果真的存储量不大可以考虑自己定义文件格式。xml 处理时Dalvik会通过自带底层的本地XML Parser解析,比如XMLpull方式,这样对于内存资源占用比较好。
Android数据存取之Preferences
这种方式应该是用起来最简单的Android读写外部数据的方法了。他的用法基本上和 J2SE(java.util.prefs.Preferences)中的用法一样,以一种简单、透明的方式来保存一些用户个性化设置的字体、颜色、位置等参数信息。一般的应用程序都会提供“设置”或者“首选项”的这样的界面,那么这些设置最后就可以通过Preferences来保存,而程序员不需要知道它到底以什么形式保存的,保存在了什么地方。当然,如果你愿意保存其他的东西,也没有什么限制。只是在性能上不知道会有什么问题。
在Android系统中,这些信息以XML文件的形式保存在 /data/data/PACKAGE_NAME /shared_prefs 目录下。
推荐阅读