java.lang.RuntimeException: android.os.TransactionTooLargeException: data parcel size 1047844 bytes
at android.app.servertransaction.PendingTransactionActions$StopInfo.run(PendingTransactionActions.java:161)
at android.os.Handler.handleCallback(Handler.java:900)
at android.os.Handler.dispatchMessage(Handler.java:103)
at android.os.Looper.loop(Looper.java:219)
at android.app.ActivityThread.main(ActivityThread.java:8349)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:513)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1055)
Caused by: android.os.TransactionTooLargeException: data parcel size 1047844 bytes
at android.os.BinderProxy.transactNative(Native Method)
at android.os.BinderProxy.transact(BinderProxy.java:532)
at android.app.IActivityTaskManager$Stub$Proxy.activityStopped(IActivityTaskManager.java:4561)
at android.app.servertransaction.PendingTransactionActions$StopInfo.run(PendingTransactionActions.java:145)
at android.os.Handler.handleCallback(Handler.java:900)
at android.os.Handler.dispatchMessage(Handler.java:103)
at android.os.Looper.loop(Looper.java:219)
at android.app.ActivityThread.main(ActivityThread.java:8349)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:513)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1055)
出现这种异常,是因为保存到缓存区的数据量过大,一般认为进程内公用缓存区不超过1M,部分android版本(如android 6.0)200k也会crush,并且不同机型表现不一样,可能有由以下原因引起:
- 启动activity、service等需要intent传递数据的组件时,intent传入了过多的复杂序列化对象;
- 启动activity、service等需要intent传递数据的组件时,intent传入的字符串占用内存过大;
- FragmentStatePagerAdapter的mSavedState列表保存的状态过多(实测将近200个就crush);
- 其他需要系统保存数据状态的组件
搞清楚了原因,就能对症下药了:
- intent的复杂对象保存到数据库,只传id过去;
- intent的过长字符串保存到数据库,传id过去;
- FragmentStatePagerAdapter使用时,viewPager不自动保存自身状态(android:saveEnabled=“false”)
- 其他组件的状态处理需要就事论事
参考:What to do on TransactionTooLargeException
|