我尝试在R.xml中设计一个首选项激活首选项屏幕,但logcat给我这个错误
09-12 22:04:16.354: E/AndroidRuntime(4641): FATAL EXCEPTION: main
09-12 22:04:16.354: E/AndroidRuntime(4641): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.nenneinc.devicelocator/com.nenneinc.devicelocator.PrefActivity}: java.lang.ClassCastException: java.lang.Boolean cannot be cast to java.lang.String
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.app.ActivityThread.access$600(ActivityThread.java:141)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.os.Handler.dispatchMessage(Handler.java:99)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.os.Looper.loop(Looper.java:137)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.app.ActivityThread.main(ActivityThread.java:5103)
09-12 22:04:16.354: E/AndroidRuntime(4641): at java.lang.reflect.Method.invokeNative(Native Method)
09-12 22:04:16.354: E/AndroidRuntime(4641): at java.lang.reflect.Method.invoke(Method.java:525)
09-12 22:04:16.354: E/AndroidRuntime(4641): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
09-12 22:04:16.354: E/AndroidRuntime(4641): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
09-12 22:04:16.354: E/AndroidRuntime(4641): at dalvik.system.NativeStart.main(Native Method)
09-12 22:04:16.354: E/AndroidRuntime(4641): Caused by: java.lang.ClassCastException: java.lang.Boolean cannot be cast to java.lang.String
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.app.SharedPreferencesImpl.getString(SharedPreferencesImpl.java:224)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.Preference.getPersistedString(Preference.java:1407)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.EditTextPreference.onSetInitialValue(EditTextPreference.java:154)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.Preference.dispatchSetInitialValue(Preference.java:1323)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.Preference.onAttachedToHierarchy(Preference.java:1135)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.PreferenceGroup.addPreference(PreferenceGroup.java:163)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.PreferenceGroup.addItemFromInflater(PreferenceGroup.java:104)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.PreferenceGroup.addItemFromInflater(PreferenceGroup.java:45)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.GenericInflater.rInflate(GenericInflater.java:488)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.GenericInflater.rInflate(GenericInflater.java:493)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.GenericInflater.inflate(GenericInflater.java:326)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.GenericInflater.inflate(GenericInflater.java:263)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.PreferenceManager.inflateFromResource(PreferenceManager.java:272)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.PreferenceActivity.addPreferencesFromResource(PreferenceActivity.java:1433)
09-12 22:04:16.354: E/AndroidRuntime(4641): at com.nenneinc.devicelocator.PrefActivity.onCreate(PrefActivity.java:13)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.app.Activity.performCreate(Activity.java:5133)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175)
09-12 22:04:16.354: E/AndroidRuntime(4641): ... 11 more
我不知道为什么,我变得疯了。 xml代码就是这个,非常简单
<PreferenceCategory android:title="Settings protection" >
<CheckBoxPreference
android:defaultValue="false"
android:title="Proteggere con password"
android:summary="Progetti con una password le tue opzioni nel caso il telefono venisse perso"
android:key="prefProtect"/>
<EditTextPreference
android:key="prefPass"
android:title="Inserire password" />
</PreferenceCategory>
<PreferenceCategory android:title="Application settings" >
<EditTextPreference
android:key="prefDel"
android:title="Elimina un numero cercandolo in archivio" />
</PreferenceCategory>
<PreferenceCategory android:title="Technical settings" >
<CheckBoxPreference
android:defaultValue="false"
android:key="prefVocal"
android:title="Abilitare comandi vocali (BETA)"
android:summary="Abilita comandi vocali per attivare o disattivare il servizio.\nDire -Activate service- per abilitare il servizio, viceversa dire -Disable service-" />
</PreferenceCategory>
PrefActivity代码就是这个
public class PrefActivity extends PreferenceActivity {
@SuppressWarnings("deprecation")
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.options);
}
}
请帮助我!
答案 0 :(得分:0)
查看您的错误:
Caused by: java.lang.ClassCastException: java.lang.Boolean cannot be cast to java.lang.String
听起来您尝试将boolean
转换为String
作为旁注, addPreferencesFromResource
可能会被弃用,
答案 1 :(得分:0)
您可以检查java代码中的以下行吗?您在以下行中出现错误
09-12 22:04:16.354: E/AndroidRuntime(4641): at android.preference.Preference.getPersistedString(Preference.java:1407)
09-12 22:04:16.354: E/AndroidRuntime(4641): at com.nenneinc.devicelocator.PrefActivity.onCreate(PrefActivity.java:13)
答案 2 :(得分:0)
您正在尝试将Boolean
个实例投射到String
。这不可能发生。请尝试以下方法:
boolean booleanValue = "true";
String s = new Boolean(booleanValue).toString();