最近在做项目的时候遇到个异常,经过反复调试,终于得知原因了
首先来看看出现异常的原因:
因为服务器开发限制,返回给我的图片资源都是使用base64编码后的String字符串,而产品要求将所有的图片能够支持Android图片库的浏览方式,于是想都没想,直接将返回的List<String>直接用
intent.putStringArrayListExtra("imgList",imageList);
包装传递到显示图片库浏览方式的activity中,只有1-2张图片是可以直接传递过去,并且能够显示成功,但是图片多的话,启动activity的时候就直接闪退了,并且出现了如下异常log:
04-28 09:53:53.471 825-1693/? E/ActivityManager: Second failure launching *.*.*Activity, giving up
android.os.TransactionTooLargeException
at android.os.BinderProxy.transactNative(Native Method)
at android.os.BinderProxy.transact(Binder.java:508)
at android.app.ApplicationThreadProxy.scheduleLaunchActivity(ApplicationThreadNative.java:916)
at com.android.server.am.ActivityStackSupervisor.realStartActivityLocked(ActivityStackSupervisor.java:1345)
at com.android.server.am.ActivityStackSupervisor.attachApplicationLocked(ActivityStackSupervisor.java:623)
at com.android.server.am.ActivityManagerService.attachApplicationLocked(ActivityManagerService.java:7326)
at com.android.server.am.ActivityManagerService.attachApplication(ActivityManagerService.java:7399)
at android.app.ActivityManagerNative.onTransact(ActivityManagerNative.java:498)
at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2815)
at android.os.Binder.execTransact(Binder.java:455)
04-28 09:53:53.506 825-1693/? E/JavaBinder: !!! FAILED BINDER TRANSACTION !!!
04-28 09:53:53.511 825-944/? E/InputDispatcher: channel '2b24ad5d *.*.*Details (server)' ~ Channel is unrecoverably broken and will be disposed!
04-28 09:53:53.513 333-928/? E/AudioFlinger: getNextBuffer, get null buffer
打了断点调试,才发现在启动Activity的时候出现异常了,如果把imageList中放入较少数据是可以成功,经过分析发现是由于bundle不能传递大容量的数据信息,所以说尽量不要使用intent传递大数据,如果两个页面之间要传递的数据较大,可以想想其他办法,比如直接简单粗暴的方法就是把要传递的数据声明为静态(static)的或者封装在一个静态类中,这种方式虽然效率比较高,但是会破坏程序的独立性(当然程序员的想法都各式各样的,具体看自己的编码思想和风格,这只是个建议),如果有想要了解两个Activity之间使用intent传值,可以参考这篇文章《多个Activity之间传值,使用Intent》