堆溢出bug定位调试修复

最近代码出了bug,堆溢出。 debug下一切正常, release时随机崩溃到某几个地方,

报错是: Critical error detected c0000374

不是完全随机崩溃,崩溃到某几个正常的地方,开始怀疑是不是这几个地方真的有什么bug,

由于使用了qt库,炸到qt函数调用最后崩溃到系统dll中,根本无法调试,最后发现了一个神器

就是 WinDbg自带的工具软件 gflags, 通过这个软件可以修改注册表让程序运行时,系统runtime分配内存时额外再前后多分配两个字节,并且填充0xfd(貌似是这个),当程序内存发生溢出时写到

额外分配的内存时就直接终端。 gflags工具下载。这个再WindowsSDK中包含了,如果没有可以去

微软官网单独下载这个sdk安装时只安装调试工具,安装完成后的路径:

C:\Program Files (x86)\Windows Kits\10\Debuggers\x64

打开里面的gflags.exe 切换到如下图选择 Image File, 注意exe只需要

文件名不需要完整路径。 下面Debugger可以不选,我选了之后有报错,

然后用vs正常启动release来调试就可以定位到,另外如果无法定位。可以

把下面的几个Enable xxx checking都勾选试试,不过这样程序运行会变很慢,

调试完记得在注册表中删除这些设置,否则程序一直运行很慢。

注册表路径是:

HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/WindowsNT/CurrentVersion/Image File Execution Options/mytest.exe

有时间研究下Windbg这个,有非常多的调试工具有助于定位bug。

也可参考这几篇博客:

Windbg的gflags.exe -- Attach调试利器_windbg gflag 挂 exe-CSDN博客

【VS】Windbg的gflags.exe调试堆栈溢出,访问越界等问题。_vs vld 越界访问-CSDN博客

相关推荐
SunkingYang2 小时前
如何下载dump(C++程序生成)文件所需要的pdb文件,包含自动下载和手动拼接下载
c++·windbg·dump·dmp·pdb下载·手动下载·拼接下载
天才测试猿4 小时前
快速定位bug,编写测试用例
自动化测试·软件测试·功能测试·测试工具·职场和发展·测试用例·bug
福大大架构师每日一题1 天前
PyTorch v2.9.1 发布:重要 Bug 修复与性能优化详解
人工智能·pytorch·bug
黑臂麒麟1 天前
Electron&OpenHarmony 跨平台实战开发(bug):npm 安装 Electron 依赖常见错误排查
electron·npm·bug·openharmony
CIb0la1 天前
Complete Bug Bounty tool List for free
linux·运维·bug
欧恩意1 天前
【Viusal Studio】关于增量链接机制
汇编·windows·bug
Austindatabases1 天前
SQLite 开发中的数据库开发规范 --如何提升业务系统性能避免基础BUG
数据库·oracle·sqlite·bug·数据库开发
万粉变现经纪人2 天前
如何解决 pip install 代理报错 407 Proxy Authentication Required 问题
windows·python·pycharm·beautifulsoup·bug·pandas·pip
爱尔兰极光2 天前
软件测试--BUG篇
bug·压力测试·测试
hadage2332 天前
windows alt + tab 切换窗口时会强制把我的中文键盘的中英文输入改为中文这个bug的曲线救国方式 da
bug