linux下用QT捕获程序异常
2021/11/21 7:10:57
本文主要是介绍linux下用QT捕获程序异常,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
linux下的QT,没有类似VS捕获系统级异常的功能,可以采用qbreakpad捕获系统级异常。用法如下:
一、部署环境,下载安装包
- 下载qbreakpad源码:
git clone https://github.com/buzzySmile/qBreakpad.git
- 下载breakpad源码
qbreakpad编译需依赖breakpad,执行以下命令安装breakpad
git clone https://github.com/google/breakpad
- 下载linux-syscall-support
没有这个文件,编译报错
git clone https://github.com/adelshokhy112/linux-syscall-support.git
- 将 beakpad 放至qBreakpad/third_party/beakpad
- 将 linux-syscall-support 里的所有文件复制到qBreakpad/third_party/lss(如果没有lss文件夹就自己新建一个)
- 编译qbreakpad
- 进入qbreakpad.pro所在目录执行qmake 生成Makefile文件
- 执行make 开始编译
- 编译成功后在handler生成静态库libqBreakpad.a
- 编译breakpad
- 如果不编译breakpad无法查看qbreakpad记录的崩溃信息
- 也要将刚才下载的 linux-syscall-support复制到breakpad/third_party/lss中一份,如果没有会报错
- 进入/third_party/breakpad,执行
./configure Make
- 如果在breakpad/src目录下生成libbreakpad.a,则编译成功
二、应用示例
.pro文件编写
QT += core gui network greaterThan(QT_MAJOR_VERSION, 4): QT += widgets #CONFIG -= app_bundle #配置上这个参数以后 你的图形界面程序就会以命令行方式运行 CONFIG -= app_bundle TARGET = catchExceptions TEMPLATE = app #config for qBreakpad # 要加上c++11,qbreakpad、breakpad都是基于c++11编写的 CONFIG += c++11 console CONFIG += warn_on CONFIG += thread exceptions rtti stl macx: LIBS += -framework AppKit #link qBreakpad library include($$PWD/qBreakpad/qBreakpad.pri) #end of config for qBreakpad DEFINES += QT_DEPRECATED_WARNINGS FORMS += \ mainwindow.ui HEADERS += mainwindow.h SOURCES += \ main.cpp\ mainwindow.cpp qnx: target.path = /tmp/$${TARGET}/bin else: unix:!android: target.path = /opt/$${TARGET}/bin !isEmpty(target.path): INSTALLS += target
源代码编写
#include "mainwindow.h" #include <QApplication> #include "QBreakpadHandler.h" int crash(int a,int b) { return a/b; } int main(int argc, char *argv[]) { QApplication a(argc, argv); QBreakpadInstance.setDumpPath(QLatin1String("crashes")); MainWindow w; w.show(); int x=5/0; crash(5,0); return a.exec(); }
当程序发生崩溃后会有如下提示,并生成存放崩溃信息的dmp文件
三、查看崩溃信息
-
在生成的可执行程序的目录下,生成.sym文件
dump_syms ./filename > filename.sym
filename为程序生成的可执行程序,例如
-
在当前目录下建一个symbols目录,symbols下的子文件夹命名为sym文件中第一行的一串字母数字
一定要严格按照这个步骤建立目录,否则无法查看崩溃信息
-
生成log日志,查看崩溃信息
minidump_stackwalk ./crashes/800f2c2e-da29-4975-49e8dd80-fc9a519a.dmp ./symbols > error.log
error.log内容如下
-
执行如下命令,可查看具体崩溃行数
addr2line 0x406263 -e '可执行程序名字' -f
这篇关于linux下用QT捕获程序异常的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-12如何创建可引导的 ESXi USB 安装介质 (macOS, Linux, Windows)
- 2024-11-08linux的 vi编辑器中搜索关键字有哪些常用的命令和技巧?-icode9专业技术文章分享
- 2024-11-08在 Linux 的 vi 或 vim 编辑器中什么命令可以直接跳到文件的结尾?-icode9专业技术文章分享
- 2024-10-22原生鸿蒙操作系统HarmonyOS NEXT(HarmonyOS 5)正式发布
- 2024-10-18操作系统入门教程:新手必看的基本操作指南
- 2024-10-18初学者必看:操作系统入门全攻略
- 2024-10-17操作系统入门教程:轻松掌握操作系统基础知识
- 2024-09-11Linux部署Scrapy学习:入门级指南
- 2024-09-11Linux部署Scrapy:入门级指南
- 2024-08-21【Linux】分区向左扩容的方法