项目上线后,Bugly上统计到错误如下:

原因很简单在Glide加载图片的时候发现发现控件所在的Activity已经被销毁了。搜索一下这个错误信息"You cannot start a load for a destroyed activity",定位问题:



即:在调用 Glide.with(context)时,页面就已经销毁了。
再看Bugly上的出错堆栈中的详细信息,分析发现在我们的详情页销毁后,接口请求完成执行了doFinally方法,在其中调用了Glide加载图片的逻辑。
查看doFinally()方法的注释:

博客讲述了在使用RxJava时遇到的问题,即在Activity销毁后,由于doFinally()方法仍会被调用,导致尝试在已销毁的Activity中加载图片(如Glide)引发错误。文章通过示例代码解释了这个问题,并提醒开发者不要在onFinally中执行UI相关的操作,以防止此类错误发生。
最低0.47元/天 解锁文章
924

被折叠的 条评论
为什么被折叠?



