报错信息:
2018-11-08 10:50:18.155 21051-21051/? E/CrashReport: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.test/com.test.ui.activity.HomeActivity}: java.lang.IllegalArgumentException: Wrong state class, expecting View State but received class android.support.design.widget.CoordinatorLayout$SavedState instead. This usually happens when two views of different type have the same id in the same hierarchy. This view's id is id/title_layout. Make sure other views do not use the same id.
at .ActivityThread.performLaunchActivity(ActivityThread.java:3194)
at .ActivityThread.handleLaunchActivity(ActivityThread.java:3302)
at .ActivityThread.-wrap12(Unknown Source:0)
at .ActivityThread$H.handleMessage(ActivityThread.java:1891)
at android.os.Handler.dispatchMessage(Handler.java:108)
at android.os.Looper.loop(Looper.java:166)
at .ActivityThread.main(ActivityThread.java:7425)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921)
Caused by: java.lang.IllegalArgumentException: Wrong state class, expecting View State but received class android.support.design.widget.CoordinatorLayout$SavedState instead. This usually happens when two views of different type have the same id in the same hierarchy. This view's id is id/title_layout. Make sure other views do not use the same id.
at android.view.View.onRestoreInstanceState(View.java:17844)
at android.view.View.dispatchRestoreInstanceState(View.java:17819)
at android.view.ViewGroup.dispatchRestoreInstanceState(ViewGroup.java:3773)
at android.view.ViewGroup.dispatchRestoreInstanceState(ViewGroup.java:3781)
at android.view.View.restoreHierarchyState(View.java:17797)
at android.support.v4.app.Fragment.restoreViewState(Fragment.java:494)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1486)
at android.support.v4.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManager.java:1784)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1852)
at android.support.v4.app.FragmentManagerImpl.dispatchStateChange(FragmentManager.java:3269)
at android.support.v4.app.FragmentManagerImpl.dispatchActivityCreated(FragmentManager.java:3229)
at android.support.v4.app.FragmentController.dispatchActivityCreated(FragmentController.java:201)
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:620)
at .AppCompatActivity.onStart(AppCompatActivity.java:178)
at .Instrumentation.callActivityOnStart(Instrumentation.java:1339)
at .Activity.performStart(Activity.java:7392)
at .ActivityThread.performLaunchActivity(ActivityThread.java:3157)
at .ActivityThread.handleLaunchActivity(ActivityThread.java:3302)
at .ActivityThread.-wrap12(Unknown Source:0)
at .ActivityThread$H.handleMessage(ActivityThread.java:1891)
at android.os.Handler.dispatchMessage(Handler.java:108)
at android.os.Looper.loop(Looper.java:166)
at .ActivityThread.main(ActivityThread.java:7425)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921)
问题原因:
布局文件中有两个控件的id是一样的。(对于普通控件,如果id一样,IDE是会提示的,但是对于include文件时,却未做提示,真奇怪。)
activity在创建时,存在相同的id不报错,但是走onRestoreInstanceState流程时,是从之前保存的序列话信息里恢复布局,出现重复id时就报错了。 经过反复测试,只有两个控件是layout类型且layout类型不同而id相同时才会有问题。

开发准则:
开发时,同一布局文件中,不能出现id重复。

















