编写:kesenhoo - 原文:http://developer.android.com/training/basics/data-storage/shared-preferences.html
如果你有一个相对较小的key-value集合需要保存,你应该使用SharedPreferences APIs。 SharedPreferences 对象指向了一个保存key-value pairs的文件,并为读写他们提供了简单的方法。每一个 SharedPreferences 文件均由framework管理,其既可以是私有的,也可以是共享的。 这节课会演示如何使用 SharedPreferences APIs 来存储与检索简单的数据。
Note: SharedPreferences APIs 仅仅提供了读写key-value对的功能,请不要与Preference APIs相混淆。后者可以帮助你建立一个设置用户配置的页面(尽管它实际上是使用SharedPreferences 来实现保存用户配置的)。如果想了解更多关于Preference APIs的信息,请参考Settings 指南。
你可以通过下面两个方法之一来创建或者访问shared preference 文件:
例如:下面的示例是在一个 Fragment 中被执行的,它会访问名为 R.string.preference_file_key
的shared preference文件,并使用private模式来打开它,这种情况下,该文件仅能被你的app访问了。
Context context = getActivity();
SharedPreferences sharedPref = context.getSharedPreferences(
getString(R.string.preference_file_key), Context.MODE_PRIVATE);
当命名你的shared preference文件时,你应该像 "com.example.myapp.PREFERENCE_FILE_KEY"
这样来命名。
当然,如果你的activity仅仅需要一个shared preference文件时,你可以使用getPreferences()方法:
SharedPreferences sharedPref = getActivity().getPreferences(Context.MODE_PRIVATE);
Caution: 如果你创建了一个MODE_WORLD_READABLE或者MODE_WORLD_WRITEABLE 模式的shared preference文件,那么任何其他的app只要知道文件名,就可以访问这个文件。
为了写shared preferences
文件,需要通过执行edit()来创建一个 SharedPreferences.Editor。
通过类似putInt()与putString()方法来传递keys与values。然后执行commit() 来提交改变. (后来有建议除非是出于线程同步的需要,否则请使用apply()方法来替代commit(),因为后者有可能会卡到UI Thread.)
SharedPreferences sharedPref = getActivity().getPreferences(Context.MODE_PRIVATE);
SharedPreferences.Editor editor = sharedPref.edit();
editor.putInt(getString(R.string.saved_high_score), newHighScore);
editor.commit();
为了从shared preference中检索读取数据,可以通过类似 getInt() 与 getString()等方法来读取。在那些方法里面传递你想要获取的value对应的key,并提供一个默认的value作为查找的key不存在时函数的返回值。如下:
SharedPreferences sharedPref = getActivity().getPreferences(Context.MODE_PRIVATE);
long default = getResources().getInteger(R.string.saved_high_score_default));
long highScore = sharedPref.getInt(getString(R.string.saved_high_score), default);