Qt使用dump文件记录并查找软件奔溃信息详细教程

Qt使用dump文件记录并查找软件奔溃信息

一、dump文件概述

1、dump文件的基本概念

dump文件通常指系统或程序在异常状态下生成的转储文件,用于记录内存、寄存器、堆栈等关键信息。常见于系统崩溃(如Windows蓝屏)或应用程序故障时自动生成,帮助开发者分析问题根源。

2、dump文件的常见类型

核心dump(Core Dump) :Unix/Linux系统在程序崩溃时生成,包含进程的内存状态。默认路径为/core/var/crash
内存转储文件(Memory Dump):Windows系统分为:

  • 小型转储(Minidump) :仅保存关键错误信息,路径为%SystemRoot%\Minidump
  • 完全转储(Complete Memory Dump) :保存全部物理内存内容,路径为%SystemRoot%\MEMORY.DMP

3、dump文件的分析工具

Windows平台

  • WinDbg:微软官方调试工具,支持分析蓝屏dump文件。
  • BlueScreenView:可视化工具,快速定位崩溃驱动。

Linux平台

  • GDB :通过gdb <程序> <core文件>命令调试。
  • Crash:专用于内核转储分析,需安装内核调试符号。

4、dump文件的应用场景

  • 调试崩溃问题:通过堆栈回溯定位异常代码位置。
  • 内存泄漏分析 :检查内存分配记录(如Windows的!heap命令)。
  • 恶意软件分析:提取进程内存中的可疑代码片段。

二、具体实现步骤

1、下载dbghelp库

在文章顶部下载

2、将库添加到自己的工程中

将下载的库文件放到工程目录下

添加到自己的工程中


此时就OK了。

3、main.cpp添加代码记录奔溃日志

cpp 复制代码
#include "mainwindow.h"

#include <QApplication>
#include <QDir>
#include <QMessageBox>


#ifdef Q_OS_WIN
#include <Windows.h>
#include <DbgHelp.h>
#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;

        // 创建Dump文件
        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
int main(int argc, char *argv[])
{
    SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)AppExceptionCallback);
    QApplication a(argc, argv);
    MainWindow w;
    w.show();
    return a.exec();
}

4、编写测试代码

mainWindow.ui文件中放置 一个按钮,然后转到槽

然后编写测试代码:

cpp 复制代码
void MainWindow::on_pushButton_clicked()
{
    int a=10/0;
    qDebug()<<a;
}

让被除数等于0.

5、测试

点击按钮程序就会奔溃

查找奔溃日志

此时log文件下就会存在dump文件

6、结果查看

打开Visual Studio直接将dump文件拖入:

相关推荐
java1234_小锋3 分钟前
周学会Matplotlib3 Python 数据可视化-绘制折线图(Lines)
开发语言·python·信息可视化·matplotlib·折线图·matplotlib3
java1234_小锋6 分钟前
一周学会Matplotlib3 Python 数据可视化-绘制直方图(Histogram)
开发语言·python·信息可视化·matplotlib·matplotlib3
拭心26 分钟前
一键生成 Android 适配不同分辨率尺寸的图片
android·开发语言·javascript
Kyln.Wu1 小时前
【python实用小脚本-182】Python一键爬取今日新闻:5分钟生成Word+CSV——再也不用复制粘贴
开发语言·python·word
沐知全栈开发1 小时前
《C 指针》深度解析
开发语言
大飞pkz2 小时前
【C#】正则表达式
开发语言·正则表达式·c#·string·字符串匹配·高效字符串匹配
猪蹄手2 小时前
C/C++基础详解(三)
开发语言·jvm·c++
别来无恙1493 小时前
Java 8 Stream API 完全指南:优雅处理集合数据
java·开发语言·streamapi
阿巴~阿巴~3 小时前
string 类元素访问方法
开发语言·c++
猫头虎3 小时前
如何实现在多跳UDP传输场景,保证单文件和多文件完整传输的成功率?
java·开发语言·网络·python·网络协议·golang·udp