SharedPreferences详解

正文

  一、结构

public interfaceSharedPreferences

android.content.SharedPreferences

  二、概述

  用于访问和修改getSharedPreferences(String, int)返回偏好设置数据(preference data)的一个接口。对于任何一组特殊的preferences,所有的客户端共享一个此类单独的实例。

修改Preferences必须通过一个SharedPreferences.Editor对象,以确保当他们提交存储数据的操作时,preference值保持一致的状态。

  注意:当前此类不支持多线程访问。后续将添加。

  (译者注:这里译为偏好设定,类似于ini文件,用于保存应用程序的属性设置)

  参见

  getSharedPreferences(String, int)

  三、内部类

interface SharedPreferences.Editor

  用于修改SharedPreferences对象设定值的接口。

  interface SharedPreferences.OnSharedPreferenceChangeListener

  接口定义一个用于在偏好设定(shared preference)改变时调用的回调函数。

  四、公共方法

public abstract booleancontains(String key)

判断preferences是否包含一个preference

参数

key想要判断的preference的名称

返回值

如果preferences中存在preference,则返回true,否则返回false

public abstract SharedPreferences.Editoredit()

针对preferences创建一个新的Editor对象,通过它你可以修改preferences里的数据,并且原子化的将这些数据提交回SharedPreferences对象。(译者注:原子化——作为一个整体提交,原子性)

注意:如果你想要在SharedPreferences中实时显示,刚通过Editor对象进行的修改,那么你必须调用commit()方法。

返回值

返回一个SharedPreferences.Editor的新实例,允许你修改SharedPreferences对象里的值。

public abstract Map<String, ?>getAll()

取得preferences里面的所有值

返回值

返回一个map,其中包含一列preferences中的键值对

异常

空指针异常(NullPointerException)

public abstract boolean getBoolean (String key, boolean defValue)

从preferences中获取一个boolean类型的值。

参数

key 获取的preference的名称

defValue当此preference不存在时返回的默认值

返回值

如果preference存在,则返回preference的值,否则返回defValue。如果使用此名称的preference不是一个boolean类型,则抛出ClassCastException

异常

ClassCastException

public abstract float getFloat (String key, float defValue)

preferences中获取一个float类型的值。

参数

key 获取的preference的名称

defValue当此preference不存在时返回的默认值

返回值

如果preference存在,则返回preference的值,否则返回defValue。如果使用此名称的preference不是一个float类型,则抛出ClassCastException

异常

ClassCastException

public abstract intgetInt(String key, int defValue)

preferences中获取一个int类型的值。

参数

key 获取的preference的名称

defValue当此preference不存在时返回的默认值

返回值

如果preference存在,则返回preference的值,否则返回defValue。如果使用此名称的preference不是一个int类型,则抛出ClassCastException

异常

ClassCastException

public abstract longgetLong(String key, long defValue)

preferences中获取一个long类型的值。

参数

key 获取的preference的名称

defValue当此preference不存在时返回的默认值

返回值

如果preference存在,则返回preference的值,否则返回defValue。如果使用此名称的preference不是一个long类型,则抛出ClassCastException

异常

ClassCastException

public abstract StringgetString(String key, String defValue)

preferences中获取一个String类型的值。

参数

key 获取的preference的名称

defValue当此preference不存在时返回的默认值

返回值

如果preference存在,则返回preference的值,否则返回defValue。如果使用此名称的preference不是一个String类型,则抛出ClassCastException

异常

ClassCastException

public abstract voidregisterOnSharedPreferenceChangeListener(SharedPreferences.OnSharedPreferenceChangeListener listener)

注册一个回调函数,当一个preference发生变化时调用。

参数

listener将会被调用的回调函数

参见

unregisterOnSharedPreferenceChangeListener(SharedPreferences.OnSharedPreferenceChangeListener)

public abstract voidunregisterOnSharedPreferenceChangeListener(SharedPreferences.OnSharedPreferenceChangeListener listener)

注销一个之前(注册)的回调函数

参数

listener要被注销的回调函数

参见

registerOnSharedPreferenceChangeListener(SharedPreferences.OnSharedPreferenceChangeListener)

  五、补充

    示例代码

      译注:Shared Preferences保存位置:/data/data/app_name/shared_prefs/*.xml

复制代码
private boolean flag = false ;

// 取得活动的Preferences对象
SharedPreferencessettings = getPreferences(Activity.MODE_PRIVATE);
// 取得值
flag = settings.getBoolean(“flag”, false );

// 取得活动的Preferences对象
SharedPreferencessettings = getPreferences( 0 );
// 取得编辑对象
SharedPreferences.Editoreditor = settings.edit();
// 添加值
editor.putBoolean(“ true ”,flag);
// 提交保存
editor.commit();
复制代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值