SharedPreferences 源码及原理

SharedPreferences 源码及原理

SharedPreferences 是Android中提供的一种轻量级数据存储方式,用来以键值对方式保存简单的数据类型。

创建流程

Android开发者通过Context的方法context.getSharedPreferences(String, Int)来获取SharedPreferences实例。Context中的具体实现如下

    @Override
    public SharedPreferences getSharedPreferences(String name, int mode) {
   
        return mBase.getSharedPreferences(name, mode);
    }

其直接调用了Context中代理模式的mBase的实现。mBase是一个ContextImpl实例。其内部方法实现如下

    // 通过名称获取SharedPreferences实例
    @Override
    public SharedPreferences getSharedPreferences(String name, int mode) {
   
        // At least one application in the world actually passes in a null
        // name.  This happened to work because when we generated the file name
        // we would stringify it to "null.xml".  Nice.
        if (mPackageInfo.getApplicationInfo().targetSdkVersion <
                Build.VERSION_CODES.KITKAT) {
   
            if (name == null) {
   
                name = "null";
            }
        }

        File file;
        synchronized (ContextImpl.class) {
   
            if (mSharedPrefsPaths == null) {
   
                mSharedPrefsPaths = new ArrayMap<>();
            }
            file = mSharedPrefsPaths.get(name);
            if (file == null) {
   
                file = getSharedPreferencesPath(name);
                mSharedPrefsPaths.put(name, file);
            }
        }
        return getSharedPreferences(file, mode);
    }
    
    // 获取文件路径
    @Override
    public File getSharedPreferencesPath(String name) {
   
        return makeFilename(getPreferencesDir(), name + ".xml");
    }
    
    // 获取文件夹路径
    private File getPreferencesDir() {
   
        synchronized (mSync) {
   
            if (mPreferencesDir == null) {
   
                mPreferencesDir = new File(getDataDir(), "shared_prefs");
            }
            return ensurePrivateDirExists(mPreferencesDir);
        }
    }

ContextImpl通过 mSharedPrefsPaths缓存文件实例,它是一个ArrayMap<String, File>格式的变量。若缓存中没有目标文件,则通过getSharedPreferencesPath()方法生成,并将其放入缓存。然后通过getSharedPreferences(File, Int)方法真正创建实例。通过源码可知,其路径在应用的getDataDir()路径下的"shared_prefs" 文件夹内,以"${name}.xml"命名

   // 通过文件获取SharedPreferences实例
    @Override
    public SharedPreferences getSharedPreferences(File file, int mode) {
   
        checkMode(mode);
        if (getApplicationInfo().targetSdkVersion >= android.os.Build.VERSION_CODES.O) {
   
            if (isCredentialProtectedStorage
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SharedPreferences是一种轻量级的Android存储机制,用于存储应用程序的简单键值对数据,比如用户设置和应用程序状态。它可以用于保存和读取少量的数据,例如用户的偏好设置、应用程序的配置信息等。 以下是SharedPreferences使用的步骤: 1. 获取SharedPreferences对象 ``` SharedPreferences preferences = getSharedPreferences("my_preferences", MODE_PRIVATE); ``` 2. 获取SharedPreferences.Editor对象 ``` SharedPreferences.Editor editor = preferences.edit(); ``` 3. 存储数据 ``` editor.putString("username", "John"); editor.putInt("age", 30); editor.putBoolean("isMarried", true); editor.commit(); ``` 4. 读取数据 ``` String username = preferences.getString("username", ""); int age = preferences.getInt("age", 0); boolean isMarried = preferences.getBoolean("isMarried", false); ``` 其中,第一个参数是键名,第二个参数是默认值。如果SharedPreferences中不存在该键,则会返回默认值。 举例: 想要记录用户的登录状态,可以使用SharedPreferences来保存和读取用户的登录信息。在登录成功后,将用户的用户名和密码保存到SharedPreferences中;在下次启动应用程序时,从SharedPreferences中读取用户的登录信息,如果已经登录,则自动跳转到主界面。 存储用户信息: ``` SharedPreferences preferences = getSharedPreferences("user_info", MODE_PRIVATE); SharedPreferences.Editor editor = preferences.edit(); editor.putString("username", "John"); editor.putString("password", "123456"); editor.putBoolean("isLogin", true); editor.commit(); ``` 读取用户信息: ``` SharedPreferences preferences = getSharedPreferences("user_info", MODE_PRIVATE); String username = preferences.getString("username", ""); String password = preferences.getString("password", ""); boolean isLogin = preferences.getBoolean("isLogin", false); if (isLogin) { // 跳转到主界面 } else { // 显示登录界面 } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值