时间:2021-02-10 14:50:17 | 栏目:Android代码 | 点击:次
1解决bug的思想:
//step1:当bug被发现(排除极低偶然性,单次性,开发工具导致)
//step2:根据经验判断bug的重现场景,多次测试,直到精准的定位bug
//step3:根据重现场景找到对应的代码
//step4:分析区域代码是否会影响到其他功能.
//step5:做好数据的备份工作.(做好代码重构和恢复的准备,这样你才能肆无忌惮的捣鼓代码)
//step6:修复代码的过程中,你会发现可能有多种解决方案.试着采取不影响主线的解决方案.以免影响到其他的代码.
//step7:回顾所有的审查和测试等工作。思考bug的出现原因,避免下次再犯同类型的错误.
2导致原因
//step1:开发中,我们需要经常需要多个Fragment间切换,并且保存每个Fragment的状态.
//step2:官方的方法是使用replace()来替换Fragment,但是replace()的调用会导致Fragment的onCreteView()被调用,所以切换界面时会无法保存当前的状态.
//step3:因此一般采用add()、hide()与show()配合,来达到保存Fragment的状态.
3原理解析
//step1:正是因为使用了Fragment的状态保存,当系统内存不足,Fragment的宿主Activity回收的时候,Fragment的实例并没有随之被回收。
//step2:Activity被系统回收时,会主动调用onSaveInstance()方法来保存视图层(View Hierarchy),然后通过onRestoreInstanceState()方法来恢复视图层.(activity中两个方法的核心代码如下) //step3:所以当Activity通过导航再次被重建时,之前被实例化过的Fragment依然会出现在Activity中 protected void onRestoreInstanceState(Bundle savedInstanceState) { if (mWindow != null) { //取出视图层 Bundle windowState = savedInstanceState.getBundle(WINDOW_HIERARCHY_TAG); if (windowState != null) { mWindow.restoreHierarchyState(windowState); } } } protected void onSaveInstanceState(Bundle outState) { //保存视图层 outState.putBundle(WINDOW_HIERARCHY_TAG, mWindow.saveHierarchyState()); Parcelable p = mFragments.saveAllState(); if (p != null) { outState.putParcelable(FRAGMENTS_TAG, p); } getApplication().dispatchActivitySaveInstanceState(this, outState); }
4解决方法(了解清楚后解决方法就容易了)
//solution1:
第一.简单的做法,就是给每层fragment加上背景色,重叠后也就看不见了
//solution2:
第二.进行判空操作.
如果为空,创建对象,add上去;
如果不为空,直接show出来;
(注意不要使用remove方法移除,hide即可)