gpt4 book ai didi

android - 为什么 PreferenceActivity 会抛出 UnsupportedEncodingException?

转载 作者:搜寻专家 更新时间:2023-11-01 08:58:55 24 4
gpt4 key购买 nike

我正在尝试使用 PreferenceActivity(我的目标是 API 级别 8)向我的应用程序添加设置,我一开始只有一个复选框:

<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
<CheckBoxPreference
android:key="pref_fps"
android:title="FPS"
android:defaultValue="false" />
</PreferenceScreen>

我的 PreferenceActivity 子类只定义了一个“onCreate”方法:

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

一开始似乎一切正常,但我注意到在应用程序重新启动后首选项丢失了。查看日志,似乎无法将首选项保存到磁盘。每次单击 PreferenceActivity 中的复选框时,都会出现此异常:

W/ApplicationContext( 9542): writeFileLocked: Got exception:
W/ApplicationContext( 9542): java.io.UnsupportedEncodingException: utf-8
W/ApplicationContext( 9542): at com.android.internal.util.FastXmlSerializer.setOutput(FastXmlSerializer.java:297)
W/ApplicationContext( 9542): at com.android.internal.util.XmlUtils.writeMapXml(XmlUtils.java:181)
W/ApplicationContext( 9542): at android.app.ContextImpl$SharedPreferencesImpl.writeFileLocked(ContextImpl.java:2928)
W/ApplicationContext( 9542): at android.app.ContextImpl$SharedPreferencesImpl.access$300(ContextImpl.java:2676)
W/ApplicationContext( 9542): at android.app.ContextImpl$SharedPreferencesImpl$EditorImpl.commit(ContextImpl.java:2861)
W/ApplicationContext( 9542): at android.preference.Preference.tryCommit(Preference.java:1198)
W/ApplicationContext( 9542): at android.preference.Preference.persistBoolean(Preference.java:1403)
W/ApplicationContext( 9542): at android.preference.CheckBoxPreference.setChecked(CheckBoxPreference.java:154)
W/ApplicationContext( 9542): at android.preference.CheckBoxPreference.onClick(CheckBoxPreference.java:143)
W/ApplicationContext( 9542): at android.preference.Preference.performClick(Preference.java:810)
W/ApplicationContext( 9542): at android.preference.PreferenceScreen.onItemClick(PreferenceScreen.java:198)
W/ApplicationContext( 9542): at android.widget.AdapterView.performItemClick(AdapterView.java:284)
W/ApplicationContext( 9542): at android.widget.ListView.performItemClick(ListView.java:3382)
W/ApplicationContext( 9542): at android.widget.AbsListView$PerformClick.run(AbsListView.java:1696)
W/ApplicationContext( 9542): at android.os.Handler.handleCallback(Handler.java:587)
W/ApplicationContext( 9542): at android.os.Handler.dispatchMessage(Handler.java:92)
W/ApplicationContext( 9542): at android.os.Looper.loop(Looper.java:144)
W/ApplicationContext( 9542): at android.app.ActivityThread.main(ActivityThread.java:4937)
W/ApplicationContext( 9542): at java.lang.reflect.Method.invokeNative(Native Method)
W/ApplicationContext( 9542): at java.lang.reflect.Method.invoke(Method.java:521)
W/ApplicationContext( 9542): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
W/ApplicationContext( 9542): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
W/ApplicationContext( 9542): at dalvik.system.NativeStart.main(Native Method)
W/ApplicationContext( 9542): Caused by: java.nio.charset.UnsupportedCharsetException: The unsupported charset name is "utf-8".
W/ApplicationContext( 9542): at java.nio.charset.Charset.forName(Charset.java:544)
W/ApplicationContext( 9542): at com.android.internal.util.FastXmlSerializer.setOutput(FastXmlSerializer.java:292)
W/ApplicationContext( 9542): ... 22 more

在模拟器和真实设备上的行为是一样的。

我做错了什么?

最佳答案

在花了更多时间调试我的应用程序后,我终于发现了问题所在:我正在使用 native 库,而这个库正在对位于 0x80000000< 的固定内存位置执行 mmap/.

在固定位置执行 mmap 并不是一个好主意。在我们的例子中,它似乎覆盖了应用程序的可用字符集。这就是 PreferenceActivity 无法将文件保存到磁盘的原因。

关于android - 为什么 PreferenceActivity 会抛出 UnsupportedEncodingException?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16852622/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com