Fragment Can not perform this action after onSaveInstanceState
首先看一下这个异常是从哪里抛出来的:
|
|
也就是在对fragment进行commit的时候,如果这时候mStateSaved
那就会抛出这个异常,而mStateSaved
是在saveAllState
也就是onSaveInstanceState
和dispatchStop
也就是Activity::onStop
中。也就是说如果在这两个生命周期方法之中或者之后对Fragment
进行Commit
就会出现这个异常。特别是DialogFragment
,一般的Fragment
还可以使用commitAllowingStateLoss
来进行”丑陋的”避免,而DialogFragment
的默认show
方法
|
|
根本不给机会。
上面说到抛出这个异常的原因,引申出什么情况下容易出现这种情况,就是异步回调的时候进行commit
。因为这个时候你无法知道当前的状态,碰巧这个时候应用进入后台,执行了onStop
或者被杀死onSaveInstanceState
,就挂了。使用Fragment
有好处,就是比Activity
轻,跳转不用进行IPC。但是真的不怎么好用,到处的坑。再说这里,例如使用MVP
,在onDestroyView
对View
进行清空,(这个是在Activity
的onDestroy
调用),也就是在这之前对View
操作都是安全的,但是Fragment
在onStop
之后就不能再进行commit
了。使用View==null
判断根本不行,真的防不胜防🤣🤣🤣。
解决办法:
Fragment全解析系列(一):那些年踩过的坑。至于为什么前面说commitAllowingStateLoss
是个”丑陋”的解决办法,这里有更详细的说明Fragment Transactions & Activity State Loss,早在13年就提及这个问题。