一.发现问题
问题:程序退出后台,修改系统字体大写,恢复app到前台,发现程序重走生命周期了,尴尬了,发生一些了骚乱。我换了其他的方式测试,都不能复现。只有修改系统字体的时候,发生了这个奇葩的问题。
那就问问度娘了,感谢这个作者:https://blog.csdn.net/libo0878/article/details/52883769
内容摘抄:
查阅了一些资料,发现在app中文字标注的单位为sp。当系统字体大小发生变化的时候sp的度量标准发生了变化,这个时候,系统会给app发送一个通知,告诉它配置已经变了,需要重新刷新界面。类似的操作就像是横竖屏切换,在onConfigurationChanged()方法里面进行需要的操作的配置。
横竖屏切换,app走的生命周期方法是onDestroy(),onCreate()。一般我们的应用通常配置是设定一个固定的方向让它避免横竖屏切换。通过配置configChanges属性,防止界面的销毁和重建。
android:screenOrientation="portrait"
android:configChanges="orientation|screenSize|keyboardHidden
回到问题本身,发生问题的原理是这样的:系统字体大小发生了变化,它在app回到前台的时候发送了一个通知告诉app。app此时走的生命周期的方法是
onDestroy()
onCreate()
onResume()
通过这样的操作进行UI界面的刷新。
重点来了:此时app是作为一种异常走的onDestroy()方法,并不是正常的按返回键进行的退出执行的onDestroy()。这个时候系统会自动在onSaveInstanceState()方法里面临时性的保存之前的界面状态或者变量信息。方便在onCreate()的时候,从bundle里面直接取出来使用。但是毕竟是异常的状态,有些实体的信息或者fragment堆栈的状态恢复的时候就有可能错乱,导致显示效果出错或者crash。
二.解决方法
android:configChanges="orientation|screenSize|keyboardHidden|fontScale
1.添加fontScale属性,避免系统字体发生变化的时候,重新create界面。如果仅仅这样处理,app的在从后台切换到前台的时候,字体会随着系统的字体大小发生变化。
2.把app里面字体的单位,由sp改为dp,这样,app的字体展示就不会随着系统的字体变化而发生变化。
可以根据产品的需要自行进行配置。