Glide异常:You cannot start a load for a destroyed activity

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

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值