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

相关推荐
东巴图8 小时前
分解如何利用c++修复小程序的BUG
开发语言·c++·bug
workflower3 天前
Fundamentals of Architectural Styles and patterns
开发语言·算法·django·bug·结对编程
lvchaoq3 天前
记录小程序真机bug,而模拟器无法复现
小程序·bug
喜欢便码3 天前
禅道提交bug的几种状态
bug
从前慢,现在也慢3 天前
(3)Bug篇
学习·bug·测试
西柚小萌新4 天前
【Bug:docker】--Docker国内镜像源加载失败
docker·容器·bug
初圣魔门首席弟子6 天前
c++ bug 记录(merge函数调用时错误地传入了vector对象而非迭代器。)
java·c++·bug
Qiuner6 天前
历劫波,明真我——Debug Commune
ai·开源·bug·debug·信息差·信息·交流
川石课堂软件测试8 天前
什么是BUG,你对BUG的了解有多少?
android·linux·服务器·python·功能测试·bug·安全性测试