MultiSelectListPreference填充类java.lang.reflect.Constructor时出错

时间:2013-07-01 12:30:02

标签: android xml android-preferences multiselectlistpreference

我目前正在尝试在我的设置中实施MultiSelectListPreference,但遇到以下错误:

E/ActivityThread: Failed to inflate
        android.view.InflateException: Binary XML file line #18: Error inflating class java.lang.reflect.Constructor
        at android.preference.GenericInflater.createItem(GenericInflater.java:397)
        at android.preference.GenericInflater.onCreateItem(GenericInflater.java:417)
        at android.preference.GenericInflater.createItemFromTag(GenericInflater.java:428)
        at android.preference.GenericInflater.rInflate(GenericInflater.java:481)
        at android.preference.GenericInflater.inflate(GenericInflater.java:326)
        at android.preference.GenericInflater.inflate(GenericInflater.java:263)
        at android.preference.PreferenceManager.inflateFromResource(PreferenceManager.java:269)
        at android.preference.PreferenceFragment.addPreferencesFromResource(PreferenceFragment.java:285)
        at com.mikebdev.refuel.SettingsActivity$SettingsFragment.onCreate(SettingsActivity.java:34)
        at android.app.Fragment.performCreate(Fragment.java:1673)
        at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:854)
        at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1057)
        at android.app.BackStackRecord.run(BackStackRecord.java:682)
        at android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1435)
        at android.app.Activity.performStart(Activity.java:5113)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2271)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2358)
        at android.app.ActivityThread.access$600(ActivityThread.java:153)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1247)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:137)
        at android.app.ActivityThread.main(ActivityThread.java:5227)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:511)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
        at dalvik.system.NativeStart.main(Native Method)
        Caused by: java.lang.reflect.InvocationTargetException
        at java.lang.reflect.Constructor.constructNative(Native Method)
        at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
        at android.preference.GenericInflater.createItem(GenericInflater.java:383)
        ... 26 more
        Caused by: java.lang.NullPointerException
        at android.content.res.AssetManager.getResourceTextArray(AssetManager.java:230)
        at android.content.res.Resources.getTextArray(Resources.java:427)
        at android.content.res.TypedArray.getTextArray(TypedArray.java:628)
        at android.preference.MultiSelectListPreference.onGetDefaultValue(MultiSelectListPreference.java:211)
        at android.preference.Preference.<init>(Preference.java:267)
        at android.preference.DialogPreference.<init>(DialogPreference.java:69)
        at android.preference.DialogPreference.<init>(DialogPreference.java:90)
        at android.preference.MultiSelectListPreference.<init>(MultiSelectListPreference.java:49)
        ... 29 more

我的XML看起来像这样:

<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
    <ListPreference
            android:defaultValue="@string/pref_amountUnit_default"
            android:dialogTitle="@string/pref_amountUnit"
            android:entries="@array/pref_amountUnit_entries"
            android:entryValues="@array/pref_amountUnit_values"
            android:key="pref_amountUnit"
            android:summary="@string/pref_amountUnit_summary"
            android:title="@string/pref_amountUnit"/>
    <ListPreference
            android:defaultValue="@string/pref_distanceUnit_default"
            android:dialogTitle="@string/pref_distanceUnit"
            android:entries="@array/pref_distanceUnit_entries"
            android:entryValues="@array/pref_distanceUnit_values"
            android:key="pref_distanceUnit"
            android:summary="@string/pref_distanceUnit_summary"
            android:title="@string/pref_distanceUnit"/>
    <MultiSelectListPreference
            android:key="pref_consumptionUnit"
            android:title="@string/pref_consumptionUnit"
            android:summary="@string/pref_consumptionUnit_summary"
            android:dialogTitle="@string/pref_consumptionUnit"
            android:entries="@array/pref_consumptionUnit_entries"
            android:entryValues="@array/pref_consumptionUnit_values"
            android:defaultValue="@string/pref_consumptionUnit_default"
            />
    <EditTextPreference
            android:defaultValue="@string/pref_moneyUnit_default"
            android:dialogTitle="@string/pref_moneyUnit"
            android:key="pref_moneyUnit"
            android:summary="@string/pref_moneyUnit_summary"
            android:title="@string/pref_moneyUnit"/>
</PreferenceScreen>

我不知道导致此错误的原因。我希望你能指出我正确的方向

3 个答案:

答案 0 :(得分:2)

MultiSelectListPreference上也有NPE。 在API 22中一切都很好,在API 15中是NPE。

在跟踪和错误之后,触发器是XML中的摘要。 以编程方式设置摘要后,没有NPE。

看起来像应用程序compat库中的错误?

答案 1 :(得分:1)

好的,我得到了它。

在我使用SharedPreferences时,我仍然在我的ListPreference中写了一个默认值。这显然不适用于MultiSelectListPreference想要创建的设置。

在尝试获取首选项时,我刚刚将getString更改为getStringSet,并为默认值创建了一个StringSet:

Set<String> consumptionUnits = new HashSet<String>();
        consumptionUnits.add("l/km");
consumption_unit = sharedPref.getStringSet("pref_consumptionUnit", consumptionUnits);

答案 2 :(得分:0)

MultiSelectListPreference的以下属性似乎导致NullPointerException(尝试解析String时)?

android:defaultValue="@string/pref_consumptionUnit_default"