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の後にこれらのエラーが発生します。
次の問題はまさにそれに関するもののようです: https://code.google.com/p/Android/issues/detail?id=1964
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();
}
タイプAオブジェクトを含むタイプAとタイプBの2つのたとえ話オブジェクトを渡したときにこの問題に直面しました。それらをパーセル可能な配列で渡し、問題は解決しました。