项目上线后,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更新等操作。