我有一个非常标准的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”