#if defined (_WIN32) || defined (WIN32)
#include <Windows.h>
#include <dbghelp.h>
#pragma comment(lib, "dbghelp.lib")
long __stdcall exceptionHander(_EXCEPTION_POINTERS*   excp);            //全局异常处理捕获
#endifint main(int argc, char *argv[])
{
#if defined (_WIN32) || defined (WIN32)SetUnhandledExceptionFilter(exceptionHander);
#endifQApplication a(argc, argv);MainWindow w;w.show();QTextCodec::setCodecForLocale(QTextCodec::codecForName("utf8"));QTextCodec::setCodecForTr(QTextCodec::codecForName("utf8"));QTextCodec::setCodecForCStrings(QTextCodec::codecForName("utf8"));return a.exec();
}/**ExceptionCode 最可能遇到的几种类型*C0000005h读写内存冲突*C0000094h非法除0*C00000FDh堆栈溢出或者说越界*80000001h由Virtual Alloc建立起来的属性页冲突*C0000025h不可持续异常,程序无法恢复执行,异常处理例程不应处理这个异常*C0000026h在异常处理过程中系统使用的代码,如果系统从某个例程莫名奇妙的返回,则出现此代码,例如调用RtlUnwind时没有ExceptionRecord参数时产生的异常填入的就是这个代码*80000003h调试时因代码中int3中断*80000004h处于被单步调试状态**返回值:**EXCEPTION_EXECUTE_HANDLER equ 1 表示我已经处理了异常,可以结束了*EXCEPTION_CONTINUE_SEARCH equ 0 表示我不处理,其他人来吧,于是windows调用默认的处理程序显示一个错误框,并结束*EXCEPTION_CONTINUE_EXECUTION equ -1 表示错误已经被修复,请从异常发生处继续执行
*/long __stdcall exceptionHander(_EXCEPTION_POINTERS*   excp)
{QDir dumpDir(QApplication::applicationDirPath() + "/dump/");if(!dumpDir.exists()){dumpDir.mkdir(QApplication::applicationDirPath() + "/dump/");}QString strPath = QApplication::applicationDirPath() + "/dump/"+  QDateTime::currentDateTime().toString("yyyy-MM-dd-hh-mm-ss")+ ".dmp";qDebug()<<strPath;//创建转储文件HANDLE hFile = CreateFile(strPath.toStdWString().c_str(), GENERIC_WRITE,FILE_SHARE_WRITE, NULL, CREATE_NEW,FILE_ATTRIBUTE_NORMAL, NULL );if(hFile != INVALID_HANDLE_VALUE){MINIDUMP_EXCEPTION_INFORMATION exptInfo;exptInfo.ThreadId = ::GetCurrentThreadId();exptInfo.ExceptionPointers = excp;//将dump信息写入到文件中MiniDumpWriteDump(GetCurrentProcess(),GetCurrentProcessId(),hFile, MiniDumpNormal,&exptInfo, NULL, NULL);}QMessageBox::critical(NULL,TR("程序异常"),TR("程序产生异常,已生成dump转储文件"));return EXCEPTION_EXECUTE_HANDLER;
}

程序是采用Qt写的,当程序运行过程中出现了crash,就会自动生成dump文件到和exe同级的dump文件夹下dump文件可以直接拖到VS里面进行分析

转载于:https://my.oschina.net/u/1262980/blog/679311

windows异常捕获生成minidump windows相关推荐

  1. 【厚积薄发系列】C++项目总结14—Windows平台下异常捕获不到问题分析

    问题背景: Windows平台常用的异常捕获函数有时候不起作用,特别是XP系统上,有些runtime error捕获不到,但是其他系统如win7.win8等又能正常捕获,导致产品发出去后遇到这类异常, ...

  2. windows下捕获dump

    一般要捕获异常只需要两个函数:SetUnhandledExceptionFilter截获异常:MiniDumpWriteDump写dump文件.但是由于CRT函数可能会在内部调用SetUnhandle ...

  3. 反调试——Windows异常-SEH

    反调试--Windows异常-SEH 京东优惠券 https://m.fenfaw.net/ 概念: SEH:Structured Exception Handling SEH是Windows默认的异 ...

  4. 异常和异常处理(windows平台)

    [翻译]异常和异常处理(windows平台) 翻译的不好,莫怪. 原文地址: http://crashrpt.sourceforge.net/docs/html/exception_handling. ...

  5. Windows异常学习笔记(四)—— 编译器扩展SEH

    Windows异常学习笔记(四)-- 编译器扩展SEH 要点回顾 编译器支持的SEH 过滤表达式 实验一:理解_try_except 实验二:_try_except 嵌套 拓展SEH结构体 scope ...

  6. 安装配置Windows AIK之生成Windows PE

    安装配置Windows AIK之生成Windows PE 1. 概述 Windows? 自动安装工具包可帮助您安装.自定义和部署 Microsoft Windows? 7 和 Windows Serv ...

  7. C#通过Windows API捕获窗,获取窗口文本(FindWindow、GetWindowText),附录:Windows窗口消息大全、Windows API大全

    文章目录 一.前言 二.使用Spy++工具分析窗口 三.C#通过Windows API捕获窗口,获取窗口文本 四.附录:Windows窗口消息 五.Windows API大全 1.API之网络函数 2 ...

  8. Windows编程捕获特定窗口及键盘鼠标消息模拟

    Windows编程捕获特定窗口及键盘鼠标消息模拟 一.简介 二.使用到的API简介 三.获取Windows记事本的编辑区窗口的句柄并模拟输入操作 1.分析 2.代码一 3.代码二 四.后记 一.简介 ...

  9. 解决VS2008 开发Windows Mobile 项目生成速度慢的问题

    EnjoyIt.Zwg 体验精细管理 享受工作乐趣 解决VS2008 开发Windows Mobile 项目生成速度慢的问题 最近用VS2008开发Windows Mobile程序,使用C#..NET ...

  10. Windows异常学习笔记(五)—— 未处理异常

    Windows异常学习笔记(五)-- 未处理异常 要点回顾 最后一道防线 实验一:理解最后一道防线 实验二:新线程的最后一道防线 总结 UnhandledExceptionFilter 实验三:理解U ...

最新文章

  1. 最新数据:一图看清全球393家独角兽公司
  2. HDU-3743 Minimum Sum,划分树模板
  3. OVH数据中心失火事件关于运维管理的思考
  4. 全球及中国健康保险市场运作模式与需求潜力预测报告2022版
  5. Arduino学习笔记36
  6. 在代理类中引用动态代理
  7. ab压力 failed_ab测试时结果显示大量Request failed的情况分析
  8. 我没让机器人变身,它自己就变了 | Science Robotics
  9. Oracle数据库之SQL单行函数---字符函数之TRIM
  10. 运行aspnet时要求启用windows集成身份验证
  11. 【Python数据分析与处理 实训01】 ---- 菜品订单信息分析(数据了解及简单统计)
  12. JAVA判断两个数是否亲和数_亲和数
  13. JS 如何调用高德地图
  14. 技术贴 | 视频清晰度由什么决定
  15. 腾讯qq企业邮箱登录入口界面如何设置
  16. 人工智能数学课高等数学线性微积分数学教程笔记(7. 最优化)
  17. 比xgboost强大的LightGBM:调参指南(带贝叶斯优化代码)
  18. 云服务器Ecs镜像迁移到新服务器
  19. 推荐一个加载动图的网站loading.io
  20. 常见攻击原理与技术分析

热门文章

  1. 2022高压电工考试模拟100题及模拟考试
  2. 博途v14电脑要求_博图TIA V14版本完整体验加测试
  3. [读书笔录]解析卷机神经网络(魏秀参)——第二章
  4. web渗透测试入门01
  5. gambit多面整合
  6. ida pro6.4 linux安装使用
  7. 关于阿里云,有什么故事?
  8. 一款万能企业邮箱,高效且实用,速看!
  9. 测试人员必备-adb常用基础命令
  10. 聚类分析matlab算例,应用Matlab聚类方法分析大坝监测资料