qt软件正常运行的崩溃了定位行号方法

软件(debug版exe或者release版exe)在正常运行状态下(不是gdb调试运行),如果软件崩掉,那么会直接闪退,软件什么也做不了,此时无法保存软件中的状态信息,此外,也无法提供任何软件崩溃原因的信息。因此,软件崩掉,我们需要能给出信息才行,指导我们修改源码。解决方法如下(针对Windows):

注:如果用vs开发qt程序,那么自带这种调试功能的,所以说vs调试功能十分强大。

这个博客不错:windows上bug崩溃定位分析(Qt或者VS)_qt程序崩溃如何错误定位-CSDN博客

一、生成crash.log日志文件(简单方便好用)

原理:软件崩掉时(例如访问空指针指向内存,除0等),系统会调用一个回调函数,在该函数中我们就可以做各种事了。

我们只需要在main函数中,SetUnhandledExceptionFilter(callback),软件崩掉时就会自动调用到callback函数中来,然后将相关信息(获取方法为开源类CCrashStack)写入到crash.log文件中,该函数中记录了当前寄存器状态,调用堆栈等信息。

一方面,可以通过 addr2line.exe查看对应得行号,另一方面,objdump.exe查看反汇编搜索一下地址也能看到行号位置。

参考博客:

Qt程序crash信息的捕捉与跟踪(qt-mingw)-CSDN博客

demo下载 https://download.csdn.net/download/lanhy999/6341987

我测试发现,数组越界,打印不出信息,这是因为CCrashStack类里面有两处注释掉就行了,至少不直接再次崩了。

二、生成dump文件

原理:软件崩溃时,记录下该软件当前所占用内存的状态,全部记录到dump文件里。还有pdb文件。

然后找一些工具分析该dump文件即可(注:dump文件不具有可读性,Dump文件的大小通常很大,可能达到几百MB或几G,得用工具分析,一般可以使用winGDB(!analyze -v命令)、Visual Studio进行调试,Qt Creatort也可以)Qt Creatort调试dump文件,定位崩溃位置_qt程序崩溃怎么定位_mahuifa的博客-CSDN博客

C++(Qt)软件调试---Windows下Qt使用dump定位崩溃位置(1)_qt程序崩溃如何错误定位-CSDN博客

可以看看他写的关于异常调试的博客,不错 mahuifa_QT,音视频,C++-CSDN博客

三、mini dump文件,这个更加轻量化

MS提供了一个API函数,MiniDumpWriteDump,(在Dbghelp.h中声明,需要导入DbgHelp.lib使用)

https://www.cnblogs.com/wangbin/p/4901261.html

qBreakpad,qt封装的一个breakpad库(google开发的),特别强大,crash.log打印不出的信息,这个都能检测出具体信息和代码位置。但是配置有点麻烦。而且,对windows下的mingw编译器好像不能用(Windows (but crash dump decoding will not work with MinGW compiler)GitHub - buzzySmile/qBreakpad: Cross-platform Qt crash handler, implemented as wrapper around google-breakpad)。

C++(Qt)软件调试---Qt使用qBreakpad定位崩溃位置(2)_qt crashpad_mahuifa的博客-CSDN博客

【QT 定位程序异常结束位置】arm环境使用 breakpad 实现程序异常崩溃定位_qt程序崩溃如何错误定位_龙行天下01的博客-CSDN博客

相关推荐
何曾参静谧2 小时前
「QT」文件类 之 QTextStream 文本流类
开发语言·qt
liyuanbhu2 小时前
Halcon HImage 与 Qt QImage 的相互转换(修订版)
qt·计算机视觉·halcon
机器视觉知识推荐、就业指导3 小时前
基于Qt/C++与OpenCV库 实现基于海康相机的图像采集和显示系统(工程源码可联系博主索要)
c++·qt·opencv
机器视觉知识推荐、就业指导3 小时前
使用 Qt 实现基于海康相机的图像采集和显示系统(不使用外部视觉库,如Halcon\OpenCv)[工程源码联系博主索要]
数码相机·qt
Qter_Sean8 小时前
自己动手写Qt Creator插件
开发语言·qt
何曾参静谧8 小时前
「QT」文件类 之 QIODevice 输入输出设备类
开发语言·qt
yyqzjw15 小时前
【qt】控件篇(Enable|geometry)
开发语言·qt
csdn_kike15 小时前
QT Unknown module(s) in QT 以及maintenance tool的更详细用法(qt6.6.0)
开发语言·qt
西西弗Sisyphus15 小时前
Qt 获取当前系统中连接的所有USB设备的信息 lsusb版
qt
kaixin_learn_qt_ing18 小时前
Qt---双缓冲绘图
qt