C++(Qt)软件调试---符号转换工具cv2pdb (24)

C++(Qt)软件调试—符号转换工具cv2pdb (24)


文章目录

  • C++(Qt)软件调试---符号转换工具cv2pdb (24)
    • @[toc]
    • 1、概述🐜
    • 2、下载cv2pdb🪲
    • 3、qt程序使用cv2pdb🦧
      • 1.1 方法1:命令行
      • 1.2 方法2:配置为qt构建步骤
      • 1.3 方法3:配置为qt creator外部工具和快捷键
    • 4、相关地址🐐

更多精彩内容
👉内容导航 👈
👉C++软件调试 👈

1、概述🐜

windows下C++程序出现异常最常用的调试方式就是分析Dump文件,而调试Dump需要使用到pdb符号表,那是不是说只有MSVC编译的程序才能调试dump呢,不是,MinGW编译的程序也可以,不过步骤复杂一些;

MinGW编译的程序生成的符号表是DWARF 格式,Windbg不支持,想要使用WinDbg调试MinGW生成的程序,就需要使用cv2pdb 工具将DWARF 格式符号表转成PDB符号表,然后就可以使用Windbg进行调试了。

演示环境:

  • 系统:

    • Windows11
  • 开发环境:

    • Qt
  • 编译器:

    • MinGW64

2、下载cv2pdb🪲

  • 下载cv2pdb
  • 解压后直接使用,无需安装。

3、qt程序使用cv2pdb🦧

这里有3中使用方式,各有优缺点。

方法1:使用命令行cv2pdb.exe name.exe生成,这种方式生成的pdb和exe的时间戳是不同的,所以部分调试工具无法使用,而windbg需要设置不校验时间戳才可以使用。

方法2:配置到qt构建步骤中,在编译程序时自动生成pdb文件,这种方法生成的pdb文件和exe时间戳相同,并且不需要命令行操作,但是不支持在Qt Creator中debug调试。

方法3:配置为qt creator外部工具,并设置快捷键,生成的pdb和exe时间戳不同,但是不需每次都使用命令行运行。

1.1 方法1:命令行

  • 创建一个Qt工程,使用mingw编译编译生成,使用debug模式进行编译,保留调试符号;
  • 在可执行程序所在路径下,鼠标右键打开终端;

在这里插入图片描述

  • 使用D:\Qt\cv2pdb-0.52\cv2pdb.exe .\TestCrash_1.1.0.exe命令将TestCrash_1.1.0.exe中的符号表转成pdb格式;
  • 注意:可执行程序只能生成一次pdb,MinGW编译生成的可执行程序符号表是包含在exe文件中的,生成pdb后,exe中就不再包含调试符号了。

在这里插入图片描述

1.2 方法2:配置为qt构建步骤

  • 创建一个qt工程,选择mingw编译器,debug模式;

  • 选择【项目】,【编译器】【构建】;

    在这里插入图片描述

  • 在【构建的步骤】处选择【添加构建步骤】【custom Process Step】;

    在这里插入图片描述

  • 在【命令】栏输入cv2pdb路径;

  • 在【参数】栏点击右侧图标,选择Executable:FilePath,这个宏表示生成的可执行程序路径,不同版本qt creator之间名称有一些区别;

    在这里插入图片描述

  • 在编译工程时就会自动生成pdb符号文件。

    在这里插入图片描述

1.3 方法3:配置为qt creator外部工具和快捷键

  • 将cv2pdb配置为qt creator的外部工具,并且设置快捷键;

  • 点击【编辑】【preferences…】,打开首选项。

    在这里插入图片描述

  • 选择【环境】【外部工具】【添加】,设置名称为cv2pdb,分别设置cv2pdb路径和可执行程序宏,点击【应用】;

    在这里插入图片描述

  • 打开【首选项】,选择【环境】【键盘】;

  • 输入cv2进行过滤,选中Tools中的cv2pdb行;

  • 点击【Record】后按下需要使用的快捷键,如果快捷键被使用了会有红色提示;

  • 设置完成后点击【应用】。

    在这里插入图片描述

  • 设置完成后使用Mingw编译生成可执行程序;

  • 点击【工具】【外部】【cv2pdb】或者按键设置的快捷键,就可以便捷的将MinGW生成的可执行程序生成pdb符号文件了。

    在这里插入图片描述

  • 使用效果如下所示:

在这里插入图片描述

4、相关地址🐐

  • C++(Qt)软件调试—无法校验pdb时间戳(23)-CSDN博客
  • cv2pdb下载地址

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/59534.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于Java Springboot宠物流浪救助系统

一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术:Html、Css、Js、Vue 数据库:MySQL 后端技术:Java、Spring Boot、MyBatis 三、运行环境 开发工具:IDEA 数据库:MySQL…

实战OpenCV之目标检测

基础入门 目标检测是计算机视觉中的一个重要任务,它旨在识别图像或视频帧中的多个对象,并对每个对象进行定位和分类。目标检测任务通常包括以下几个主要步骤。 输入图像:接收一张或多张图像作为输入。 特征提取:从输入图像中提取有用的特征。 候选区域生成:生成一组可能包…

如何在手机上完整下载B站视频并保存到相册?

作为国内最受欢迎的视频平台之一,B站(哔哩哔哩)不仅有丰富的创作者内容,还吸引了大量年轻用户。对于热爱动画、影视剪辑、Vlog等各类视频的观众来说,有时希望能将这些视频下载到手机相册中,方便随时观看或分享。如何在不损失画质的…

uniapp隐藏自带的tabBar

uniapp隐藏自带的tabBar 场景: 微信小程序在使用自定义tabBar组件时, 隐藏uniapp自带的tabBar <template> <!-- index页面 --> </template> <script setup> import { onShow } from /utils/wxUtils onShow(() > {uni.hideTabBar() // 隐藏自带的tab…

My_SQL day3

知识点&#xff1a;约束 1.dafault 默认约束 2.not null 非空约束 3.unique key 唯一约束 4.primary key 主键约束 5.anto_increment 自增长约束 6.foreign key 外键约束 知识点&#xff1a;表关系 1.一对一 2.一对多 3.多对多 知识点&#xff1a;约束 1.default 默认约束 …

C++基础:Pimpl设计模式的实现

2024/11/14: 在实现C17的Any类时偶然接触到了嵌套类的实现方法以及Pimpl设计模式&#xff0c;遂记录。 PIMPL &#xff08; Private Implementation 或 Pointer to Implementation &#xff09;是通过一个私有的成员指针&#xff0c;将指针所指向的类的内部实现数据进行隐藏。 …

从JVM的角度,来分析为什么Java中是值传递?

从 JVM 的角度来看&#xff0c;Java 中的参数传递之所以是值传递&#xff0c;是因为在 JVM 执行方法调用时&#xff0c;参数的值&#xff08;不论是基本类型还是引用类型&#xff09;都被复制并压入调用栈的帧&#xff08;stack frame&#xff09;中。让我们从 JVM 的内存模型和…

Navicat 17 功能简介 | 单元格编辑器

Navicat 17 功能简介 | 单元格编辑器 本期&#xff0c;我们一起了解 Navicat 17 出色的数据操作功能的单元格编辑器。单元格编辑器支持文本、十六进制、图像和网页四种格式的数据编辑&#xff0c;位于底部的编辑器窗格&#xff0c;为你编辑更大容量的数据信息提供足够的显示和操…

Unity自动LOD工具AutoLOD Mesh Decimator的使用

最近在研究大批量物体生成&#xff0c;由于我们没有专业美术&#xff0c;在模型减面工作上没有人手&#xff0c;所以准备用插件来实现LOD功能&#xff0c;所以找到了AutoLOD Mesh Decimator这个插件。 1&#xff0c;导入插件后&#xff0c;我们拿个实验的僵尸狗来做实验。 空…

爬虫补环境案例---问财网(rpc,jsdom,代理,selenium)

目录 一.环境检测 1. 什么是环境检测 2.案例讲解 二 .吐环境脚本 1. 简介 2. 基础使用方法 3.数据返回 4. 完整代理使用 5. 代理封装 6. 封装所有使用方法 jsdom补环境 1. 环境安装 2. 基本使用 3. 添加参数形式 Selenium补环境 1. 简介 2.实战案例 1. 逆向目…

免费,WPS Office教育考试专用版

WPS Office教育考试专用版&#xff0c;不仅满足了考试需求&#xff0c;更为教育信息化注入新动力。 https://pan.quark.cn/s/609ef85ae6d4

Vue前端开发,组件及组件的使用

什么是组件 组件(Component)是Vue中最强大的功能之一&#xff0c;每个Vue 文件就是一个个独立的组件&#xff0c;组件也可以被其他组件调用&#xff0c;形成嵌套关系&#xff0c;大部分的应用都是由各类不同功能的小组件进行构建&#xff0c;形成一个功能强大的大组件树系统&a…

Docker 中启动 NGINX 并配置 HTTPS 443 端口

在 Docker 中启动 NGINX 并配置 HTTPS 443 端口时&#xff0c;你需要挂载 SSL 证书和密钥文件&#xff0c;并更新 NGINX 配置文件。以下是详细步骤&#xff1a; 1. 准备证书文件 确保你有 SSL 证书和私钥文件&#xff0c;通常是两个文件&#xff1a; certificate.crt&#x…

政务数据治理专栏开搞!

写在前面 忙忙碌碌干了一年政务数据治理的工作&#xff0c;从法人数据到自然人&#xff0c;从交通到地理信息等等&#xff0c;突发想法开一个专栏讲一讲政务数据遇到的问题&#xff0c;以及治理的成效&#xff0c;或许有朋友爱看。 政务数据&#xff0c;又称之为政务数据资源&a…

前端在PC端实现支付思路流程

一.去支付 1.前端点击“去支付”按钮&#xff0c;请求订单详情接口&#xff0c;传递订单的id、订单号给后端和请求支付方式接口 2.后端返回支付信息和支付方式数据 二.弹出支付窗口 接收支付信息和支付方式数据后&#xff0c;前端弹出支付弹窗 三.确认支付 前端无论选择任何…

The 3rd Universal CupStage 15: Chengdu, November 2-3, 2024(2024ICPC 成都)

Problem L. Recover Statistics 题目意思&#xff1a; 给定a, b, c三个值&#xff0c;确保构造的数列中包含满足题目的数量 解题思路&#xff1a; 100 中 选择a 50个&#xff0c; b45个&#xff0c; c4个。 #include <iostream>using namespace std;using ll long …

VUE3实现好看的世界建筑中国建筑网站源码

文章目录 1.设计来源1.1 网站主界面1.2 登录界面1.3 注册界面1.4 特色建筑展览界面1.5 世界建筑介绍界面1.6 世界建筑介绍 - 详情界面1.7 中国建筑介绍界面1.8 中国建筑介绍 - 详情界面1.9 关于我们界面 2.效果和源码2.1 动态效果2.2 源代码2.3 目录结构 源码下载万套模板&…

「人眼视觉不再是视频消费的唯一形式」丨智能编解码和 AI 视频生成专场回顾@RTE2024

你是否想过&#xff0c;未来你看到的电影预告片、广告&#xff0c;甚至新闻报道&#xff0c;都可能完全由 AI 生成&#xff1f; 在人工智能迅猛发展的今天&#xff0c;视频技术正经历着一场前所未有的变革。从智能编解码到虚拟数字人&#xff0c;再到 AI 驱动的视频生成&#…

「QT」文件类 之 QTemporaryFile 临时文件类

✨博客主页何曾参静谧的博客&#x1f4cc;文章专栏「QT」QT5程序设计&#x1f4da;全部专栏「Win」Windows程序设计「IDE」集成开发环境「UG/NX」BlockUI集合「C/C」C/C程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计「File」数据文件格式「UG/NX」NX定制…

和 Nostr 探索 Web5 的未来

Nostr 是一个我过去两年一直在关注的协议。跟所有社区一样&#xff0c;Nostr 的发展也是起起伏伏&#xff0c;有过一些破圈被主流熟悉的时刻&#xff0c;也有一些像现在这样可能让人会觉得有点沉寂的时刻。但我还是经常关注 Nostr&#xff0c;没有特别的原因&#xff0c;就是单…