今天项目中碰到一个和activity生命周期有关的坑,特此记录。
背景:activity launchMode="singlenInstance",在多次启动关闭后,在最后一次关闭(调用finish),生命只走到了onPause,此时再次launch后,这两次的生命周期变成:onCreate--->onResume----->onPause------->onCreate---->onResume---->onStop----->onDestroy------>onPause
因为在onStop的时候,我会通过EventBus发送消息来结束自己,这就导致了bug现象:一直不能launch,看不到界面起来
解析:
第一个启动的activity暂记录为A,后面那次启动记录为B。虽说是singlenInstance,但是在Afinish调用后,虽说只到onPause没有onDestroy,此时再次启动,是另一个对象B,通过this的log输出可以看出。
因此生命周期其实是这样:
onCreate(A)--->onResume(A)----->onPause(A)------->onCreate(B)---->onResume(B)---->onStop(A)----->onDestroy(A)------>onPause(B)
当A onPause时,又launch了B,B到onResume后,会call到A的onStop和onDestroy,在A的onStop会发送消息去finish,因为B也注册了相同消息,因此B刚被启动就被finish了
方案:
在onCreate时用local变量记录当前activity对象,当onStop时,判断如果local变量=this,则调用finish,否则不调用。这样在A的onStop时,local变量已经变成B了,因此不会再发消息去调用finish了