1、前言
dump文件是C++程序发生异常时,保存当时程序运行状态的文件,是调试异常程序重要的方法,所以程序崩溃时,除了日志文件,dump文件便成了我们查找错误的最后一根救命的稻草。
2、依赖库下载
生成dump需要有Dbghelp的库,正常来说VS、qt都自带了。如果没有,私信我发你。
3、项目配置
3.1、设置输出路径
步骤:右击项目-》属性-》配置属性-》常规 -》输出路径
设置一个固定的输出路径,是为了方便存放deghelp.dll
动态库。
3.2、拷贝依赖资源
1、将头文件拷贝至和main.cpp同级。
2、将dbghelp.lib
静态库、dbghelp.dll
动态库拷贝至输出目录下(如果没有输出目录,请先运行一遍程序即可)
3.3 将dbghelp.h添加在工程中
步骤:右击头文件目录-》点击添加-》现有项
3.4、配置lib文件路径
步骤:右击项目-》属性-》配置属性-》链接器 -》输入-》附加依赖项 输入dbghelp.lib
3.5、添加生成minidump文件方法
在main.cpp中添加MyUnhandledExceptionFilter
方法。然后在main函数的开头添加SetUnhandledExceptionFilter(MyUnhandledExceptionFilter);
代码。
#include <windows.h> #include <Dbghelp.h> LONG WINAPI MyUnhandledExceptionFilter(struct _EXCEPTION_POINTERS* ExceptionInfo) { HANDLE lhDumpFile = CreateFile(L".\\bin_D\\miniDumpFile.dmp", GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); MINIDUMP_EXCEPTION_INFORMATION loExceptionInfo; loExceptionInfo.ExceptionPointers = ExceptionInfo; loExceptionInfo.ThreadId = GetCurrentThreadId(); loExceptionInfo.ClientPointers = TRUE; MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), lhDumpFile, MiniDumpNormal, &loExceptionInfo, NULL, NULL); CloseHandle(lhDumpFile); return EXCEPTION_EXECUTE_HANDLER; } int main() { SetUnhandledExceptionFilter(MyUnhandledExceptionFilter); //.... return 0; }
4、测试效果
在main中添加下面的代码,然后运行,将会在工作路径下看到miniDumpFile.dmp
文件
int test(int a, int b) { return a / b; } int main() { SetUnhandledExceptionFilter(MyUnhandledExceptionFilter); int a = 1; int b = 0; std::cout << test(a, b) << std::endl; //.... return 0; }
见下图。
5、打开dump文件进行定位
有VS的情况下,可以直接双击xx.dmp文件。然后点击右侧的【仅限本机调试】
然后我们就可以看到程序崩溃的位置,这时我们还可以查看堆栈、内存的信息。加快排查错误。