博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[C++]Qt程式异常崩溃处理技巧(Win)
阅读量:6462 次
发布时间:2019-06-23

本文共 3101 字,大约阅读时间需要 10 分钟。

文章转载来自     http://www.cnblogs.com/lcchuguo/p/5177715.html     作者 

https://blog.csdn.net/baidu_33570760/article/details/52221863

 

这篇文章谈的是 Qt4 程式在视窗系统下的异常崩溃处理技巧。所以须要在头文件里包括“#include <Windows.h>”。

首先,程式难免会有异常崩溃的时候。重要的是在崩溃时能及时把重要的数据保存好,将损失减少。

SetUnhandledExceptionFilter函数是Win32API的异常捕获函数,在程式异常结束前。会调用该函数注冊的回调函数,这样就能在进程终止前运行指定的代码,达到比如保存数据的功能。

1 LONG ApplicationCrashHandler(EXCEPTION_POINTERS *pException){
//程式异常捕获 2 /* 3 ***保存数据代码*** 4 */ 5 //这里弹出一个错误对话框并退出程序 6 EXCEPTION_RECORD* record = pException->ExceptionRecord; 7 QString errCode(QString::number(record->ExceptionCode,16)),errAdr(QString::number((uint)record->ExceptionAddress,16)),errMod; 8 QMessageBox::critical(NULL,"程式崩溃","
对于发生的错误,表示诚挚的歉意
"+ 9 QString("
错误代码:%1
错误地址:%2
").arg(errCode).arg(errAdr),10 QMessageBox::Ok);11 return EXCEPTION_EXECUTE_HANDLER;12 }13 14 int main(int argc, char *argv[])15 {16 QApplication a(argc, argv);17 QTextCodec::setCodecForTr(QTextCodec::codecForLocale());18 QTextCodec::setCodecForCStrings(QTextCodec::codecForLocale());19 QTextCodec::setCodecForLocale(QTextCodec::codecForLocale());20 SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)ApplicationCrashHandler);//注冊异常捕获函数21 MainWindow w;22 w.showMaximized();23 return a.exec();24 }

保存数据仅是拯救措施,更重要的是找到错误的根源。若能在崩溃的同一时候,程式自己主动记录下崩溃时的执行信息,将有助于修正工作。微软提供了“DbgHelp”错误调试技术。调用相关功能就可以保存程式崩溃时的信息,然后借助WinDbg软件就能分析出当时的执行状况。

调用“DbgHelp”的MiniDumpWriteDump函数保存以“.dmp”为后缀的Dump文件,该文件能被WinDbg读取并分析。

你须要加入头文件“#include <DbgHelp.h>”,在Pro文件里加入“LIBS += -lDbgHelp”。目的是链接DbgHelp库。

1 LONG ApplicationCrashHandler(EXCEPTION_POINTERS *pException){
//程式异常捕获 2 /* 3 ***保存数据代码*** 4 */ 5 //创建 Dump 文件 6 HANDLE hDumpFile = CreateFile(QTime::currentTime().toString("HH时mm分ss秒zzz.dmp").utf16(), GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); 7 if( hDumpFile != INVALID_HANDLE_VALUE){ 8 //Dump信息 9 MINIDUMP_EXCEPTION_INFORMATION dumpInfo;10 dumpInfo.ExceptionPointers = pException;11 dumpInfo.ThreadId = GetCurrentThreadId();12 dumpInfo.ClientPointers = TRUE;13 //写入Dump文件内容14 MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hDumpFile, MiniDumpNormal, &dumpInfo, NULL, NULL);15 }16 //这里弹出一个错误对话框并退出程序17 EXCEPTION_RECORD* record = pException->ExceptionRecord;18 QString errCode(QString::number(record->ExceptionCode,16)),errAdr(QString::number((uint)record->ExceptionAddress,16)),errMod;19 QMessageBox::critical(NULL,"程式崩溃","
对于发生的错误,表示诚挚的歉意
"+20 QString("
错误代码:%1
错误地址:%2
").arg(errCode).arg(errAdr),21 QMessageBox::Ok);22 return EXCEPTION_EXECUTE_HANDLER;23 }

当被错误困扰得焦头烂额的时候。若是老天能直接告诉错误在哪一行代码该有多好呀。其实WinDbg就能做到。

在项目的proproject文件里增加:QMAKE_LFLAGS_RELEASE = /INCREMENTAL:NO /DEBUG

这句话的目的是Release版也将生成“.pdb”后缀的调试信息文件。在使用WinDbg导入Dump前。指定好源代码与pdb文件的位置。就可以在错误报告内看到罪魁祸首是哪一行代码。

 

转载于:https://www.cnblogs.com/FKdelphi/p/10731775.html

你可能感兴趣的文章
MYSQL导入导出.sql文件(转)
查看>>
使用Elasticsearch、Logstash、Kibana与Redis(作为缓冲区)对Nginx日志进行收集(转)
查看>>
git review报错一例
查看>>
Tomcat在Linux上的安装与配置
查看>>
《信息安全系统设计基础》 课程教学
查看>>
Linux平台下使用rman进行oracle数据库迁移
查看>>
全栈工程师学习Linux技术的忠告
查看>>
iOS自定制tabbar与系统的tabbar冲突,造成第一次点击各个item图片更换选中,第二次选中部分item图片不改变...
查看>>
C# Dictionary用法总结
查看>>
SVN服务器使用(二)
查看>>
反射获取内部类以及调用内部类方法
查看>>
C语言 - pthread
查看>>
谈Linq To Sql的优劣--纯个人观点
查看>>
HDU 4996 Revenge of LIS(DP)
查看>>
App里面如何正确显示用户头像
查看>>
DATAGUARD维护:从库宕机后如何恢复到管理恢复模式
查看>>
Android中的PID和UID
查看>>
MAC下上公司内网
查看>>
CentOS7.4安装mysql5.7
查看>>
U-BOOT之一:BootLoader 的概念与功能
查看>>