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

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



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

翻译过来就是当观察者(下游)的onError、onCompleted事件回调后,或者调用disposed之后会调用到doFinally,每次订阅都会调用一次onFinally事件回调。
写个简单的demo测试一下:
class BaseUseActivity : AppCompatActivity() {
lateinit var mBinding: ActivityBaseUseBinding
var disposable: Disposable? = null
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
mBinding = ActivityBaseUseBinding.inflate(layoutInflater)
setContentView(mBinding.root)
mBinding.btnTest01.setOnClickListener {
//计时5秒,发送事件
Observable.timer(5, TimeUnit.SECONDS)
.doOnSubscribe {
println("------------------doOnSubscribe------------")
disposable = it
}
.doFinally {
println("------------doFinally------------")
}
.subscribe(object :Observer<Long>{
override fun onSubscribe(d: Disposable) {
disposable=d
}
override fun onNext(t: Long) {
println("------------onNext------------")
}
override fun onError(e: Throwable) {
println("----------------onError------------")
}
override fun onComplete() {
println("-------------onComplete------------")
}
})
}
}
override fun onDestroy() {
super.onDestroy()
println("-------------------onDestroy------------")
//取消事件监听
disposable?.dispose()
}
}

总结:因为Rxjava中onFinally回调,即使disposed之后还会执行,所以不能在此方法中执行UI更新等操作。
博客讲述了在使用RxJava时遇到的问题,即在Activity销毁后,由于doFinally()方法仍会被调用,导致尝试在已销毁的Activity中加载图片(如Glide)引发错误。文章通过示例代码解释了这个问题,并提醒开发者不要在onFinally中执行UI相关的操作,以防止此类错误发生。

981

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



