Qt 项目中集成 qBreakpad 生成崩溃 dump 文件

1、Release 模式保留调试信息

  1. Release 模式默认会开启代码优化、移除调试符号(如变量名、函数行号),而 dump 文件需要调试符号才能解析出具体的崩溃位置。

  2. QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO:开启 Release 优化 + 保留调试符号

    复制代码
    # 对 C++ 编译选项:使用"带调试信息的 Release 编译 flags"
    QMAKE_CXXFLAGS_RELEASE = $$QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO
    # 对链接选项:使用"带调试信息的 Release 链接 flags"
    QMAKE_LFLAGS_RELEASE = $$QMAKE_LFLAGS_RELEASE_WITH_DEBUGINFO

2、引用 qBreakpad 模块

  1. 通过 .pri 文件统一管理 qBreakpad 的编译依赖(头文件、库文件),避免在每个模块中重复配置。

  2. 注意:若使用 MinGW 编译器,LIBS 中的库文件后缀会变为 .a(如 -lqBreakpad.a),且路径需对应 MinGW 版本的库。

    复制代码
    # 1. qBreakpad 依赖的 Qt 模块(根据实际版本调整,部分版本可能不需要 network)
    QT += network
    # 2. 编译选项:启用线程、异常处理、RTTI(运行时类型信息)、STL 支持
    #    (qBreakpad 内部使用这些特性,缺少会导致编译失败)
    CONFIG += thread exceptions rtti stl
    
    # 3. 头文件路径:指定 qBreakpad 头文件所在目录($${PWD} 是当前 .pri 文件的路径)
    INCLUDEPATH += $${PWD}/include
    # 4. 库文件路径:指定 qBreakpad 静态库(.lib)所在目录,并链接库文件
    LIBS += -L$${PWD}/lib -lqBreakpad

3、初始化 qBreakpad 并设置 Dump 路径

复制代码
   1. 首先包含 qBreakpad 的头文件
   2. 设置 Dump 文件路径(关键:路径必须可写入)
   3. 初始化 qBreakpad(QBreakpadInstance 通常是 qBreakpad 提供的单例类)
   QBreakpadInstance::instance()->setDumpPath(dumpPath);  // 不同 qBreakpad 版本的接口可能不同,需匹配

4、调试dump文件

  1. 将dump文件拖入到visual studio中,点击设置符号路径
  2. 将程序生成的.pdb文件夹位置添加到符号文件位置
  3. 点击使用仅限本机进行调试
相关推荐
Tony小周7 小时前
使用QKeyEvent keyPress(QEvent::KeyPress, key模拟键盘发送事件,会导致主程序卡死
嵌入式硬件·qt
Larry_Yanan8 小时前
QML学习笔记(五十)QML与C++交互:QML中单例C++对象
开发语言·c++·笔记·qt·学习·ui·交互
zhmhbest10 小时前
Qt 全球峰会 2025:中国站速递 —— 技术中立,拥抱更大生态
开发语言·qt·系统架构
feiyangqingyun13 小时前
Qt实时绘制飞行轨迹/移动轨迹实时显示/带旋转角度/平滑移动/效果一级棒/地面站软件开发/无人机管理平台
qt·无人机·集群地面站
十五年专注C++开发16 小时前
Qt-VLC: 一个集成VLC的开源跨平台媒体播放库
开发语言·qt·媒体·libvlc·vlc-qt
Aevget20 小时前
QtitanNavigation助力能源数字化转型:打造清晰可控的系统导航体验
c++·qt·嵌入式·能源·界面控件·ui开发
寻找华年的锦瑟1 天前
Qt Quick Application&&Qt Quick Application (compat)
开发语言·qt
上去我就QWER1 天前
Qt中如何获取系统版本信息
开发语言·qt
十五年专注C++开发1 天前
Qt-Nice-Frameless-Window: 一个跨平台无边框窗口(Frameless Window)解决方案
开发语言·c++·qt
江公望1 天前
装了新的QtCreator17,没有用Qt5.12自带的QtCreator4,导致QtCreator17无法找到Qt5.12帮助文档
qt·qml