Qt [获取Dump] 使用WindowsAPI实现生成MiniDump文件

说明

客户现场的软件偶发崩溃是程序开发者,比较头疼的事情。如何更快速的定位到问题点和解决掉,是开发应该具备的基本能力。

Windows提供了一系列的API,可以记录软件崩溃前的堆栈信息。下面就实现一个生成Dump文件的程序实例。

主要代码

回调AppExceptionCallback

cpp 复制代码
#ifdef Q_OS_WIN
#include <windows.h>
#include <dbgHelp.h>
#endif

#ifdef Q_OS_WIN
#pragma comment(lib, "dbghelp.lib")
LONG WINAPI AppExceptionCallback(struct _EXCEPTION_POINTERS* ExceptionInfo)
{
    QString logFile = QApplication::applicationDirPath() + "/Log";
    if (!QDir(logFile).exists())
    {
        QDir().mkdir(logFile);
    }

    QString dumpName = QString("%1/%2.dmp").arg(logFile).arg(QDateTime::currentDateTime().toString("yyyy_MM_dd hh_mm_ss"));
    HANDLE hDumpFile = CreateFileW(dumpName.toStdWString().c_str(), GENERIC_READ | GENERIC_WRITE, FILE_SHARE_WRITE | FILE_SHARE_READ, 0, CREATE_ALWAYS, 0, 0);
    if (hDumpFile != INVALID_HANDLE_VALUE)
    {
        MINIDUMP_EXCEPTION_INFORMATION dumpInfo;
        dumpInfo.ThreadId = GetCurrentThreadId();
        dumpInfo.ExceptionPointers = ExceptionInfo;
        dumpInfo.ClientPointers = TRUE;

        MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hDumpFile, MiniDumpWithDataSegs, ExceptionInfo ? &dumpInfo : nullptr, nullptr, nullptr);
        CloseHandle(hDumpFile);
    }

    QMessageBox::critical(nullptr, QString("Application Error"), QString("Application is Crash!"), QMessageBox::Ok);
    return EXCEPTION_EXECUTE_HANDLER;
}
#endif

main函数调用SetUnhandledExceptionFilter

cpp 复制代码
int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    #ifdef Q_OS_WIN
    SetUnhandledExceptionFilter(AppExceptionCallback);
    #endif
    Widget w;
    w.show();
    return a.exec();
}

编译问题

问题解决办法,记录在另一篇文章:

相关推荐
Sylvia-girl1 小时前
Java——抽象类
java·开发语言
Yana.nice3 小时前
Bash函数详解
开发语言·chrome·bash
tomorrow.hello5 小时前
Java并发测试工具
java·开发语言·测试工具
晓13135 小时前
JavaScript加强篇——第四章 日期对象与DOM节点(基础)
开发语言·前端·javascript
老胖闲聊5 小时前
Python I/O 库【输入输出】全面详解
开发语言·python
她说人狗殊途7 小时前
java.net.InetAddress
java·开发语言
天使day7 小时前
Cursor的使用
java·开发语言·ai
Dxy12393102167 小时前
Python ExcelWriter详解:从基础到高级的完整指南
开发语言·python
源代码•宸9 小时前
C++高频知识点(十三)
开发语言·c++·经验分享·面经
wa的一声哭了9 小时前
python基础知识pip配置pip.conf文件
java·服务器·开发语言·python·pip·risc-v·os