首选项库导致 E/libc & E/Pref 错误

Ste*_*ail 8 logcat sharedpreferences android-studio preferencefragment

我正在使用 MVVM 和改造构建一个天气应用程序,我最近添加了一个 PreferencesFragmentCompat 子类来使用首选项库实现一些用户设置。这样做之后,我的应用程序将无法运行,并且我不断收到以下几行错误:

2020-04-08 00:54:12.346 18079-18079/? E/de.flogaweathe: Unknown bits set in runtime_flags: 0x8000
2020-04-08 00:54:12.410 18079-18079/com.nesoinode.flogaweather E/libc: Access denied finding property "ro.vendor.df.effect.conflict"
2020-04-08 00:54:12.421 18079-18110/com.nesoinode.flogaweather E/Perf: Fail to get file list com.nesoinode.flogaweather
2020-04-08 00:54:12.421 18079-18110/com.nesoinode.flogaweather E/Perf: getFolderSize() : Exception_1 = java.lang.NullPointerException: Attempt to get length of null array
2020-04-08 00:54:12.421 18079-18110/com.nesoinode.flogaweather E/Perf: Fail to get file list oat
2020-04-08 00:54:12.422 18079-18110/com.nesoinode.flogaweather E/Perf: getFolderSize() : Exception_1 = java.lang.NullPointerException: Attempt to get length of null array
Run Code Online (Sandbox Code Playgroud)

我不知道这些是什么,我在堆栈或谷歌上找不到任何具体的答案。没有迹象表明是什么导致了错误,所以我不知道我是否做错了什么是图书馆的问题。有任何想法吗?

这是我从 xml 资源文件添加首选项的 SettingsFragment :

class SettingsFragment : PreferenceFragmentCompat() {
    override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
        addPreferencesFromResource(R.xml.settings_prefs)
    }
}
Run Code Online (Sandbox Code Playgroud)

这是我从 sharedPrefs 中读取一些值的方式:

class UnitProviderImpl(context: Context) : UnitProvider {

    private val appContext = context.applicationContext
    private val preferences:SharedPreferences
        get() = PreferenceManager.getDefaultSharedPreferences(appContext)

    override fun getUnitSystem(): String {
        val selectedUnitSystemName = preferences.getString(UNIT_SYSTEM_KEY,
            UnitSystem.SI.name.toLowerCase(Locale.ROOT))
        return selectedUnitSystemName!!
    }
}
Run Code Online (Sandbox Code Playgroud)

Ste*_*ail 0

经过更多研究后,我设法找到了解决该问题的方法。首先,我注释掉了与首选项库(以及库本身)相关的所有代码,然后再次运行应用程序。运行成功,没有任何错误,因此将范围缩小到androidx.preference:preference-ktx:1.1.0库本身,因为我的代码经过了审查,没有发现任何问题。查看偏好文档,我想我可以尝试可能已经解决了这个问题的 beta 或 alpha 版本。你瞧,在使用androidx.preference:preference-ktx:1.1.0-beta01测试版并取消相关代码的注释后,一切又恢复正常了。