Qt工程生成MiniDump文件

  • 关于Dump的文件介绍在这里,今天要介绍的是如何在Qt工程生成Dump文件。
  1. 首先我们在Qt的pro文件(工程配置文件)要取消优化,并加入调试信息,如下:
#加入调试信息
QMAKE_CFLAGS_RELEASE += -g
QMAKE_CXXFLAGS_RELEASE += -g
#禁止优化
QMAKE_CFLAGS_RELEASE -= -O2
QMAKE_CXXFLAGS_RELEASE -= -O2
#release在最后link时默认有"-s”参数,表示"Omit all symbol information from the output file",因此要去掉该参
win32:!msvc{
    QMAKE_LFLAGS_RELEASE = -mthreads
}else{
    #message("msvc version")
    #QMAKE_CFLAGS_RELEASE = -O2 -MD -Zi
    #QMAKE_LFLAGS_RELEASE = /INCREMENTAL:NO /DEBUG
    #QMAKE_LFLAGS_RELEASE += /MAP
    #QMAKE_CFLAGS_RELEASE += /Zi
    #QMAKE_LFLAGS_RELEASE += /debug /opt:ref
    QMAKE_LFLAGS_RELEASE += /MAP /DEBUG /opt:ref /INCREMENTAL:NO
}
  1. 同样,在pro文件中加入生成Dump文件的依赖库——DBghelp.lib,User32.lib
LIBS += \
-lUser32 \
-lDbghelp
  1. 接着我们要定义生成dump文件的函数入口,然后把入口添加在main函数的入口处,一般是在main函数的第一行。如下
#include <Windows.h>
#include <DbgHelp.h>
#include <winnt.h>
#include <time.h>
#include <locale>
#include <codecvt>
LONG __stdcall ApplicationCrashHandler(EXCEPTION_POINTERS *pException)
{
    //程式异常捕获
    //创建 Dump 文件
    char str_time[100];
    memset(str_time, 0, 100);
    struct tm *local_time = NULL;
    time_t utc_time;
    utc_time = time(NULL);
    local_time = localtime(&utc_time);
    strftime(str_time, 100, "%Y%m%d%H%M%S", local_time);

    std::string timeStr(str_time);
    std::string dumpFilePath = timeStr + ".dmp";
    std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> converter;
    std::wstring wide = converter.from_bytes(dumpFilePath);
    HANDLE hDumpFile = CreateFile(wide.c_str(),GENERIC_WRITE, 0, nullptr, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, nullptr);
    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);
    }
    //这里弹出一个错误对话框并退出程序
    EXCEPTION_RECORD* record = pException->ExceptionRecord;
    fprintf(stderr, "record->ExceptionCode:%lu\n", record->ExceptionCode);
    return EXCEPTION_EXECUTE_HANDLER;
}
#include<tchar.h>
void DisableSetUnhandledExceptionFilter()
{
    HMODULE h_hand = LoadLibrary(_T("kernel32.dll"));

    void *addr = (void*)GetProcAddress(h_hand,"SetUnhandledExceptionFilter");
    if (addr)
    {
        unsigned char code[16];

        int size = 0;

        code[size++] = 0x33;

        code[size++] = 0xC0;

        code[size++] = 0xC2;

        code[size++] = 0x04;

        code[size++] = 0x00;

        DWORD dwOldFlag, dwTempFlag;

        VirtualProtect(addr, size, PAGE_READWRITE, &dwOldFlag);

        WriteProcessMemory(GetCurrentProcess(), addr, code, size, NULL);

        VirtualProtect(addr, size, dwOldFlag, &dwTempFlag);
    }
}

void RunCrashHandlerLocal()
{
SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)ApplicationCrashHandler);//注册异常捕获函数
}

int main()
{
    RunCrashHandlerLocal();
    int a = 9;
    int b = 0;
    int c = 0;
    c = a / b;//产生程序异常并崩溃
    return 0;
}

以上就完成一个最简版本的
注:
1). 生成dump必须得是msvc的编译器才行,使用mingw编译器生成不了dump文件
2). pro文件适用于qt工程,以上代码同样试用于vs工程,只需要在vs工程中取消优化,并将相应的库——DBghelp.lib,User32.lib添加到工程即可

测试工程下载地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容