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

4 篇文章 0 订阅
4 篇文章 0 订阅

第一步:在pro中链接Lib

LIBS += -lDbgHelp

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

#include <windows.h>

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

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

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

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

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

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
在 Windows 系统中,当程序崩溃时,操作系统会自动生成一个 .dmp 文件,也就是所谓的 Dump 文件,其中包含了程序崩溃时的一些现场信息。当程序开发者拿到 Dump 文件后,就可以通过调试工具来分析崩溃原因,从而修复程序中的问题。 在 Qt 工程中,如果在 main 函数中发生了异常,一般可以通过以下代码来进行处理: ``` int main(int argc, char *argv[]) { qInstallMessageHandler(myMessageOutput); QApplication app(argc, argv); try { // ... } catch (std::exception &e) { qCritical() << "Exception caught: " << e.what(); return 1; } return app.exec(); } ``` 这样,在异常发生时,程序会输出异常信息并退出,同时会生成一个 Dump 文件。但是,如果异常发生在其他地方,例如某个函数中,那么就需要在该函数中进行相应的异常处理,并在处理完异常后手动触发生成 Dump 文件的功能。 一种常见的方法是使用 MiniDumpWriteDump 函数来生成 Dump 文件。例如: ``` #include <windows.h> #include <dbghelp.h> void generateDump(EXCEPTION_POINTERS* pException) { HANDLE hDumpFile = CreateFile("myapp.dmp", GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); if (hDumpFile != INVALID_HANDLE_VALUE) { MINIDUMP_EXCEPTION_INFORMATION exceptionInfo; exceptionInfo.ThreadId = GetCurrentThreadId(); exceptionInfo.ExceptionPointers = pException; exceptionInfo.ClientPointers = FALSE; MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hDumpFile, MiniDumpNormal, &exceptionInfo, NULL, NULL); CloseHandle(hDumpFile); } } void foo() { // ... __try { // ... } __except (generateDump(GetExceptionInformation()), EXCEPTION_EXECUTE_HANDLER) { // ... } } ``` 这段代码中,我们定义了一个 generateDump 函数来生成 Dump 文件,并在 foo 函数中使用 __try 和 __except 块来捕获异常并触发生成 Dump 文件的功能。注意,这里的 EXCEPTION_EXECUTE_HANDLER 参数表示异常处理程序应该被执行。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值