web-dev-qa-db-ja.com

Android.support.v7.widget.Toolbar $ SavedStateをアンマーシャリングするときのClassNotFoundException

Androidクラッシュレポートに次のエラーが表示されます:

Android.os.BadParcelableException: ClassNotFoundException when unmarshalling: Android.support.v7.widget.Toolbar$SavedState
   at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:2318)
   at Android.app.ActivityThread.handleLaunchActivity(ActivityThread.Java:2396)
   at Android.app.ActivityThread.handleRelaunchActivity(ActivityThread.Java:3974)
   at Android.app.ActivityThread.access$900(ActivityThread.Java:139)
   at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:1299)
   at Android.os.Handler.dispatchMessage(Handler.Java:102)
   at Android.os.Looper.loop(Looper.Java:149)
   at Android.app.ActivityThread.main(ActivityThread.Java:5257)
   at Java.lang.reflect.Method.invokeNative(Method.Java)
   at Java.lang.reflect.Method.invoke(Method.Java:515)
   at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.Java:793)
   at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:609)
   at dalvik.system.NativeStart.main(NativeStart.Java)
Caused by: Android.os.BadParcelableException: ClassNotFoundException when unmarshalling: Android.support.v7.widget.Toolbar$SavedState
   at Android.os.Parcel.readParcelableCreator(Parcel.Java:2154)
   at Android.os.Parcel.readParcelable(Parcel.Java:2104)
   at Android.os.Parcel.readValue(Parcel.Java:2020)
   at Android.os.Parcel.readSparseArrayInternal(Parcel.Java:2382)
   at Android.os.Parcel.readSparseArray(Parcel.Java:1742)
   at Android.os.Parcel.readValue(Parcel.Java:2077)
   at Android.os.Parcel.readArrayMapInternal(Parcel.Java:2321)
   at Android.os.Bundle.unparcel(Bundle.Java:249)
   at Android.os.Bundle.getSparseParcelableArray(Bundle.Java:1273)
   at com.Android.internal.policy.impl.PhoneWindow.restoreHierarchyState(PhoneWindow.Java:1744)
   at Android.app.Activity.onRestoreInstanceState(Activity.Java:1017)
   at Android.app.Activity.performRestoreInstanceState(Activity.Java:989)
   at Android.app.Instrumentation.callActivityOnRestoreInstanceState(Instrumentation.Java:1138)
   at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:2284)
   at Android.app.ActivityThread.handleLaunchActivity(ActivityThread.Java:2396)
   at Android.app.ActivityThread.handleRelaunchActivity(ActivityThread.Java:3974)
   at Android.app.ActivityThread.access$900(ActivityThread.Java:139)
   at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:1299)
   at Android.os.Handler.dispatchMessage(Handler.Java:102)
   at Android.os.Looper.loop(Looper.Java:149)
   at Android.app.ActivityThread.main(ActivityThread.Java:5257)
   at Java.lang.reflect.Method.invokeNative(Method.Java)
   at Java.lang.reflect.Method.invoke(Method.Java:515)
   at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.Java:793)
   at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:609)
   at dalvik.system.NativeStart.main(NativeStart.Java)

アクティビティを再開すると、断続的に発生するようです。どのコードでも、SavedStateクラスに直接アクセスすることはありません。

編集:私のアクティビティのレイアウトXmlは

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:layout_width="match_parent"
Android:layout_height="match_parent"
Android:background="@color/white"
Android:orientation="vertical">

<include layout="@layout/toolbar" />
....

そしてツールバーXMLは

<?xml version="1.0" encoding="utf-8"?>
<Android.support.v7.widget.Toolbar xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:app="http://schemas.Android.com/apk/res-auto"
Android:id="@+id/toolbar"
Android:layout_width="match_parent"
Android:layout_height="wrap_content"
Android:background="?attr/colorPrimary"
Android:minHeight="?attr/actionBarSize"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"/>

そして私のアクティビティのonCreateで私はします

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    setContentView(R.layout.activity_show_txn);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);
    getSupportActionBar().setDisplayHomeAsUpEnabled(true);

    localBroadcastManager = LocalBroadcastManager.getInstance(getApplicationContext());
    mResources = getResources();

    if (savedInstanceState != null) {
        long id = savedInstanceState.getLong(STA_TXN_ID);
        ...
    } else {
        ... read fresh
    }

    mDateTV = (TextView) findViewById(R.id.ASTVDate);
    mDayTV = (TextView) findViewById(R.id.ASTVDay);
    mCatName = (TextView) findViewById(R.id.ASTVCatName);
    mMonthTV = (TextView) findViewById(R.id.ASTVMonth);
    ....

    Calendar c = Java.util.Calendar.getInstance();
    c.setTime(txn.getTxnDate());
    mDateTV.setText("" + c.get(Calendar.DAY_OF_MONTH));
    mDayTV.setText(c.getDisplayName(Calendar.DAY_OF_WEEK, Calendar.LONG, Locale.US));
    mMonthTV.setText(c.getDisplayName(Calendar.MONTH, Calendar.LONG, Locale.US));
}

そして、私はappcompat-v7:22.1.1を使用していますが、proguardの後にこれらのエラーが発生します。

20
Aalap

次の問題はまさにそれに関するもののようです: https://code.google.com/p/Android/issues/detail?id=1964

3
AAverin

AAverinのソースによると Google Issue 1964 、ビルドツールバージョン24には修正が含まれています。

例: build.gradleでビルドツールのバージョンを変更します:

buildToolsVersion "24.0.0"

または、(私の特定のケースでは)キャッチすることでクラッシュを防ぎます:

try {
    // Temporary fix for crash issue
    mapView.onCreate(savedInstanceState);
} catch (Throwable t) {
    t.printStackTrace();
}
1
Alan

タイプAオブジェクトを含むタイプAとタイプBの2つのたとえ話オブジェクトを渡したときにこの問題に直面しました。それらをパーセル可能な配列で渡し、問題は解決しました。

0
Deepali Maniyar