onSharedPreferenceChanged

onSharedPreferenceChanged

我有一个非常标准的PreferenceFragment使用

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    addPreferencesFromResource(R.xml.settings);

    prefs = getPreferenceScreen().getSharedPreferences();
}

 @Override
public void onResume() {
    super.onResume();
    prefs.registerOnSharedPreferenceChangeListener(this);

    updatePreferences(getPreferenceScreen());
}

@Override
public void onSharedPreferenceChanged(SharedPreferences prefs, String key) {
    Log.d(TAG, "onSharedPreferenceChanged " + key);
    updatePreference(findPreference(key));
}

@Override
public void onPause() {
    super.onPause();
    prefs.unregisterOnSharedPreferenceChangeListener(this);
}


在settings.xml中,我引用了一个DialogPreference,它看起来像这样:

@Override
protected void onDialogClosed(boolean ok) {
    super.onDialogClosed(ok);

    if (ok) {
        Log.d(TAG, "onDialogClosed OK");

        SharedPreferences.Editor editor = settings.edit();
        editor.putString(SettingKeys.SOME_KEY, X);
        final boolean commit = editor.commit();
        Log.d(TAG, "onDialogClosed commit: " + commit);
    }
}


但是,我得到以下序列:

onDialogClosed OK
onSharedPreferenceChanged SOME_KEY
onDialogClosed commit: true


这意味着onSharedPreferenceChanged事件是在最终提交完成之前触发的。这意味着我的PreferenceFragment无法读取onSharedPreferenceChanged处理程序中的最新值……这使我发疯。

有什么建议吗?

最佳答案

除非我缺少任何东西,否则您的顺序实际上是正确的:


“ onDialogClosed OK”是第一个打印输出
然后,您得到编辑器,设置一些键
您正在调用editor.commit()。 When a shared preference is changed, added, or removed,onShared onSharedPreferenceChanged()被触发,然后打印第二行:“ onSharedPreferenceChanged SOME_KEY”。
提交后,剩余的行将显示为“ onDialogClosed commit:true”

10-05 18:59