文章目录
- 一、Qt程序Release版本记录崩溃信息,并定位问题代码
- 1. Release版本程序中生成pdb调试信息文件
- 2. 添加代码将程序崩溃时的堆栈保存为crash.dmp文件
- 3.使用 WinDbg 分析crash.dmp文件
- 二、跨平台生成dump的开源项目
- 三、参考资料
一、Qt程序Release版本记录崩溃信息,并定位问题代码
pdb文件,后缀*.pdb,是程序的符号文件。
dump文件,后缀*.dmp,是程序崩溃时的内存转储文件;
windows平台下微软有成熟的分析工具,比如VS和windbg。
1. Release版本程序中生成pdb调试信息文件
在.pro文件中加入如下语句:
QMAKE_LFLAGS_RELEASE = /INCREMENTAL:NO /DEBUG
或者在项目 —> 构建步骤 中,将Generate separate debug info勾选。
2. 添加代码将程序崩溃时的堆栈保存为crash.dmp文件
在.pro文件中加入如下语句:
LIBS += -lDbgHelp
#include <Windows.h>
#include <DbgHelp.h>
#include <QApplication>
#include <QMessageBox>
// 保存程序异常崩溃的信息
LONG ApplicationCrashHandler(EXCEPTION_POINTERS *pException)
{
//创建 Dump 文件
HANDLE hDumpFile = CreateFile(L"crash.dmp", GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
if(hDumpFile != INVALID_HANDLE_VALUE)
{
//Dump 信息
MINIDUMP_EXCEPTION_INFORMATION dumpInfo;
dumpInfo.ExceptionPointers = pException;
dumpInfo.ThreadId = GetCurrentThreadId();
dumpInfo.ClientPointers = TRUE;
// 写入 dump 文件内容
MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hDumpFile, MiniDumpNormal, &dumpInfo, NULL, NULL);
}
//弹出一个错误对话框
QMessageBox msgBox;
msgBox.setText("application crash!");
msgBox.exec();
return EXCEPTION_EXECUTE_HANDLER;
}
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
//注册异常捕获函数
SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)ApplicationCrashHandler);
// set printf and fprintf out immediately
setvbuf(stdout, NULL, _IONBF, 0);
setvbuf(stderr, NULL, _IONBF, 0);
OctNisus w;
w.show();
return a.exec();
}
github地址
3.使用 WinDbg 分析crash.dmp文件
如果主程序有多层嵌套,例如主程序下还有动态库,那么下一次需将动态库的.pdb和动态库的源码打开,再打开同一个crash.dmp进行更深成次的定位。
1.打开WinDbg(x64)(windbg.exe);
2.File —> Symbol File Path,设置.pdb文件对应文件夹;
3.File —> Source File Path,设置源代码对应文件夹;
4.File —> Open Crash Dump,打开crash.dmp文件。
5.输入!analyze –v命令,这个命令是最简单也是最实用的的调试命令。
另外如果是Qt+MinGW, 还可以使用addr2line.exe。
二、跨平台生成dump的开源项目
在不同的平台下,生成dump文件的方式都不同。谷歌的开源项目叫Breakpad,统一了这三平台win、linux、mac生成dump的方式,通过它就可以跨平台。
Github地址:https://github.com/google/breakpad
另一个开源项目叫qBreakpad,使用Qt对Breakpad进一步封装,使用更简单。
Github地址:https://github.com/buzzySmile/qBreakpad
三、参考资料
- Qt程序Release版本记录崩溃信息,并定位问题代码
- windows上bug崩溃定位分析(Qt或者VS)
- 12.5-使用Qt实现跨平台C++崩溃捕获,看这一篇就足够了(Breakpad)
- (Windbg调试二)Windows下c++程序崩溃问题定位
- Windows 平台定位C语言工程内存泄漏
- Qt dump崩溃调试简单整理
- Windows下Qt生成dump文件并定位bug(基于qBreakpad)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)