项目上线后,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: ActivityBaseUseBindingvar disposable: Disposable? = nulloverride 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更新等操作。