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之 运行时错误总结

相关推荐
wdfk_prog9 小时前
[Linux]学习笔记系列 -- lib/sort.c 通用的排序库(Generic Sorting Library) 为内核提供标准的、高效的排序功能
linux·运维·c语言·笔记·stm32·学习·bug
SundayBear18 小时前
HardFault_Handler处理Bug
bug
利来利往18 小时前
【奇怪的bug】lua的nil不报错
开发语言·bug·lua
初圣魔门首席弟子3 天前
flag使用错误出现bug
c++·bug
初圣魔门首席弟子4 天前
友元类和友元函数bug
bug
初圣魔门首席弟子4 天前
switch缺少break出现bug
c++·算法·bug
毕设源码-邱学长4 天前
【开题答辩全过程】以 Bug交流网站为例,包含答辩的问题和答案
bug
debug 小菜鸟4 天前
aws 实战小bug
云计算·bug·aws
黑客飓风4 天前
RTX 4090算力应用
人工智能·chrome·bug
布拉格沃兹基硕德4 天前
MacOS报错“zsh: command not found: brew”【已解决】
macos·bug