Qt 使用DbgHelp和SetUnhandledExceptionFilter来获取Crash log/dump文件

Posted 一杯清酒邀明月

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Qt 使用DbgHelp和SetUnhandledExceptionFilter来获取Crash log/dump文件相关的知识,希望对你有一定的参考价值。

第一步:在pro中链接Lib

LIBS += -lDbgHelp

#pragma comment(lib , "DbgHelp.lib")

第二步:在main源文件中添加

#include <windows.h>

第三步:在main源文件中创建回调函数:

 1 LONG CreateCrashHandler(EXCEPTION_POINTERS *pException){
 2     //创建 Dump 文件
 3     QDateTime CurDTime = QDateTime::currentDateTime();
 4     QString current_date = CurDTime.toString("yyyy_MM_dd_hh_mm_ss");
 5     //dmp文件的命名
 6     QString dumpText = "Dump_"+current_date+".dmp";
 7     EXCEPTION_RECORD *record = pException->ExceptionRecord;
 8     QString errCode(QString::number(record->ExceptionCode, 16));
 9     QString errAddr(QString::number((uint)record->ExceptionAddress, 16));
10     QString errFlag(QString::number(record->ExceptionFlags, 16));
11     QString errPara(QString::number(record->NumberParameters, 16));
12     HANDLE DumpHandle = CreateFile((LPCWSTR)dumpText.utf16(),
13              GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
14     if(DumpHandle != INVALID_HANDLE_VALUE) {
15         MINIDUMP_EXCEPTION_INFORMATION dumpInfo;
16         dumpInfo.ExceptionPointers = pException;
17         dumpInfo.ThreadId = GetCurrentThreadId();
18         dumpInfo.ClientPointers = TRUE;
19         //将dump信息写入dmp文件
20         MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(),DumpHandle, MiniDumpNormal, &dumpInfo, NULL, NULL);
21         CloseHandle(DumpHandle);
22     }
23     //创建消息提示
24     QMessageBox::warning(NULL,"Dump",QString("ErrorCode%1  ErrorAddr:%2  ErrorFlag:%3 ErrorPara:%4").arg(errCode).arg(errAddr).arg(errFlag).arg(errPara),
25         QMessageBox::Ok);
26     return EXCEPTION_EXECUTE_HANDLER;
27 }

第四步:在main函数中添加注册dump回调函数

 1 int main(int argc, char *argv[])
 2 {
 3     QApplication a(argc, argv);
 4     //获取系统编码
 5     QTextCodec *codec = QTextCodec::codecForLocale();    
 6     QTextCodec::setCodecForLocale(QTextCodec::codecForLocale());
 7     //注冊异常捕获函数
 8     SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)CreateCrashHandler);
 9     /***代码实现***/
10 }

这样就可以实现crashlog的保持和警告窗口提示。

以上是关于Qt 使用DbgHelp和SetUnhandledExceptionFilter来获取Crash log/dump文件的主要内容,如果未能解决你的问题,请参考以下文章

使用 Dbghelp.h 的函数列表

使用dbghelp生成dump文件以及事后调试分析

使用dbghelp生成dump文件以及事后调试分析

dbghelp.dll 定位异常奔溃信息

如何追踪哪个应用程序将 dbghelp 注入所有其他进程?

VS自带的dbghelp.h文件 报错