No view found for id 0x7f0901c3 for fragment解决以及线上bug排查技巧

情景再现

开发这么久,不知道你们是否也经历过这样的情况,测试或者用户,反馈app闪退,结果你自己打开开发工具,去调试,一切正常,然后闪退还是存在,只是在开发环境中不能重现。这种情况一般是在特定的情况下才触发的bug。比如app退出后台,再打开的时候,重启了,这样你在开发环境很难模拟到。那这种bug怎么来排查的,两种办法:

集成bugly

bugly是个很好的工具,

腾讯Bugly,为移动开发者提供专业的异常上报和运营统计,帮助开发者快速发现并解决异常,同时掌握产品运营动态,及时跟进用户反馈。

具体怎样集成自行百度。集成以后,可以查看到很多开发环境看不到的bug,这样就根据崩溃记录,对app进行完善。

bug重现

虽然bugly能看到日志,但是怎么才能重现呢,毕竟不重现,没办法解决bug,能重现的bug,其实是最好解决的Bug。对于一些bug,可能加一些判断非空就行了,但是有些bug,比较难重现,比如

No view found for id 0x7f0901c3 (包名:id/frameLayout) for fragment MergedModuleNoLoginFragment{acdaeec} (156480ac-26ef-4bdc-8ec6-ae57f092d97f id=0x7f0901c3)

包名.UI.onStart(UI.java:75)

这个bug困扰了我好久,开发环境始终重现不了,加了try-catch也不行,然后网上的方法都试了,也不行。这个bug的原因就是一句话:调用的时机不对,还没初始化完成,就切换了。这个bug一般会在fragment嵌套fragment的代码里出现。现在将解决办法说一下

开发环境重现bug

其实一些bug,正常情况下是重现不了的,我们可以通过设置开发者选项里的不保留活动 ,调试的时候,正常进入页面,然后点击home键,回到桌面,再点击图标,就有可能重现一些Bug

我这边的bug解决,是将切换fragment的方法,放在onCreate()方法里,有可能view还没初始化,就调用了,会报错

   @Override
    protected void onStart() {
        super.onStart();
        // 加载主页面
        showMainFragment();
    }

   
 private void showMainFragment()
    {
        if (mainFragment == null && !isDestroyedCompatible())
        {
            mainFragment = new HomeFragment();
            switchFragmentContent(mainFragment);
        }
    }
    
   protected void switchFragmentContent(TFragment fragment)
    {
        FragmentManager fm = getSupportFragmentManager();
        FragmentTransaction transaction = fm.beginTransaction();
        transaction.replace(fragment.getContainerId(), fragment);
        try
        {
            transaction.commitNowAllowingStateLoss();
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }
    }

报错的代码是MainFragment里的子fragment切换

css 复制代码
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_main, container, false);
        mSupportFragmentManager = getParentFragmentManager();
        mTransaction = mSupportFragmentManager.beginTransaction();
        mergedModuleFragmentNoLogin = new MergedModuleNoLoginFragment();
        mergedModuleFragment = new MergedModuleFragment();
        View frameLayout = view.findViewById(R.id.frameLayout);
        if (frameLayout != null) {
            if (!Contants.DOCTOR_LOGIN) {
                mTransaction.add(R.id.frameLayout, mergedModuleFragmentNoLogin);
            } else {
                mTransaction.add(R.id.frameLayout, mergedModuleFragment);
            }
            mTransaction.commitAllowingStateLoss();
        }


        return view;
    }

mTransaction.add(R.id.frameLayout, mergedModuleFragment);

报错,找不到R.id.frameLayout。放到了onStart()方法里就可以了

关于这个Bug,网上有一些博客,我把筛选过,感觉有用的博客分享一下
Fragment找不到资源Id引起的线上Crash
从一个线上 Android Bug 回看 Fragment
java.lang.IllegalArgumentException No view found for id 0x7
java.lang.IllegalArgumentException No view found for id 0x... for fragment
Fragment嵌套fragment出现的两种错误No view found for id for fragment 与Can not perform this action after onSave
java.lang.IllegalArgumentException: No view found for id 崩溃总结
关于No view found for id 0x7f080135 (com.xxx.xxx:id/viewpager) for fragment PopupWindow
遇到的错误之java.lang.IllegalArgumentException: No view found for id
Android之 运行时错误总结

相关推荐
m0_748239838 小时前
前端bug调试
前端·bug
沙尘暴炒饭1 天前
关于uni-forms组件的bug【提交的字段[‘*‘]在数据库中并不存在】
bug
Kisorge2 天前
【C语言】代码BUG排查方式
c语言·开发语言·bug
安卓机器2 天前
探索 Python编程 调试案例:配置日志记录器查看程序运行bug
bug
树懒_Zz4 天前
记录 io.springfox 3.0.0 整合 spring boot 2.6.x 由于 springfox bug 引发问题
windows·spring boot·bug
每天进步一大步5 天前
webSokect安卓和web适配的Bug 适用实时语音场景
android·前端·bug·web
JWASX5 天前
【BUG记录】Apifox 参数传入 + 号变成空格的 BUG
java·bug·urlencoder·urldecoder
初遇你时动了情5 天前
解决react 路由切换,页面闪屏的bug
javascript·react.js·bug
老赵的博客5 天前
QString转const char* bug
bug
andlbds6 天前
解决PCL库中pcl::VoxelGrid降采样Bug
c++·bug