目录

  • 1、前言
  • 2、依赖库下载
  • 3、项目配置
  • 3.1、设置输出路径
  • 3.2、拷贝依赖资源
  • 3.3 将dbghelp.h添加在工程中
  • 3.4、配置lib文件路径
  • 3.5、添加生成minidump文件方法
  • 4、测试效果
  • 5、打开dump文件进行定位
  • 相关文章


1、前言

dump文件是C++程序发生异常时,保存当时程序运行状态的文件,是调试异常程序重要的方法,所以程序崩溃时,除了日志文件,dump文件便成了我们查找错误的最后一根救命的稻草。

2、依赖库下载

生成dump需要有Dbghelp的库,正常来说VS、qt都自带了。如果没有,私信我发你。

3、项目配置

3.1、设置输出路径

步骤:右击项目-》属性-》配置属性-》常规 -》输出路径

android binder dump 日志 下载dump日志_c++

设置一个固定的输出路径,是为了方便存放deghelp.dll动态库。

android binder dump 日志 下载dump日志_Qt_02

3.2、拷贝依赖资源

1、将头文件拷贝至和main.cpp同级。

android binder dump 日志 下载dump日志_动态库_03


2、将dbghelp.lib静态库、dbghelp.dll动态库拷贝至输出目录下(如果没有输出目录,请先运行一遍程序即可)

android binder dump 日志 下载dump日志_Qt_04

3.3 将dbghelp.h添加在工程中

步骤:右击头文件目录-》点击添加-》现有项

android binder dump 日志 下载dump日志_c++_05

3.4、配置lib文件路径

步骤:右击项目-》属性-》配置属性-》链接器 -》输入-》附加依赖项 输入dbghelp.lib

android binder dump 日志 下载dump日志_Qt_06

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;
}

见下图。

android binder dump 日志 下载dump日志_开发语言_07

5、打开dump文件进行定位

有VS的情况下,可以直接双击xx.dmp文件。然后点击右侧的【仅限本机调试】

android binder dump 日志 下载dump日志_动态库_08

然后我们就可以看到程序崩溃的位置,这时我们还可以查看堆栈、内存的信息。加快排查错误。

android binder dump 日志 下载dump日志_Qt_09