使用代码手工生成dmp文件

  • SetUnhandledExceptionFilter

为每个线程设置SetUnhandledExceptionFilter(MyCallBack),(必须在每个线程中启动时调用一次,否则造成无法进入回调函数中)这样该线程中发现未处理的 SEH 异常时就会进入到MyCallBack 回调中.

无聊的是虽然MyCallBack 的参数是 SEH 异常的结构体指针,但 C++异常也会进入到MyCallBack 中.所以只要SetUnhandledExceptionFilter 就能抓到 C++的异常了.

按C++标准,未处理的C++异常应当是触发unexpected.而MS 放出话说它的编译器只触发terminate.而在MFC 中居然terminate 都不触发了,直接变成了 SEH 而进入了MyCallBack.

部分源码:

#include "stdafx.h"
#include "DumpHandle.h"  
#include <stdlib.h>
#include <stdio.h>
#include <dbghelp.h>
#pragma comment(lib, "Dbghelp.lib")

LONG WINAPI DumpHandleFilterA(struct _EXCEPTION_POINTERS *lpExceptionInfo)
{
LONG ret = EXCEPTION_EXECUTE_HANDLER;
char szFileName[128] = {0};
SYSTEMTIME st = {0};
  
::GetLocalTime(&st); 
 
wsprintfA(szFileName, ("CrashAt[%04d-%02d-%02d-%02d-%02d-%02d-%02d-%02d].dmp"), 
st.wYear, st.wMonth, st.wDay, st.wHour, st.wMinute, st.wSecond, st.wMilliseconds, rand()%100);
HANDLE hFile = ::CreateFileA(szFileName, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL );
if (hFile != INVALID_HANDLE_VALUE)
{
MINIDUMP_EXCEPTION_INFORMATION ExInfo;         
ExInfo.ThreadId = ::GetCurrentThreadId();       
ExInfo.ExceptionPointers = lpExceptionInfo;        
ExInfo.ClientPointers = false;       
// write the dump        
BOOL bOK = MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hFile, MiniDumpNormal, &ExInfo, NULL, NULL );         
if (bOK)
{
DumpDbgPrintA(("Create Dump File Success!/n")); 
DumpDbgMsgboxA("Create Dump File Success!/n");
}
else
{
DumpDbgPrintA(("MiniDumpWriteDump Failed: %d/n"), GetLastError() ); 
DumpDbgMsgboxA(("MiniDumpWriteDump Failed: %d/n"), GetLastError() );
}
::CloseHandle(hFile);
}
else
{
DumpDbgPrintA(("Create File %s Failed %d/n"), szFileName, GetLastError());
DumpDbgMsgboxA(("Create File %s Failed %d/n"), szFileName, GetLastError()); 
}
 
   
return ret;
}

void DumpDbgPrintA (char *fmt, ... )
{
va_list argptr;/* Argument list pointer*/
char str[1024*3] = {0};/* Buffer to build sting into*/

va_start (argptr, fmt);/* Initialize va_ functions*/
wvsprintfA (str, fmt, argptr);/* prints string to buffer*/
OutputDebugStringA(str);
va_end (argptr);/* Close va_ functions*/
}

void DumpDbgMsgboxA (char *fmt, ... )
{
va_list argptr;/* Argument list pointer*/
char str[1024*3] = {0};/* Buffer to build sting into*/

va_start (argptr, fmt);/* Initialize va_ functions*/
wvsprintfA (str, fmt, argptr);/* prints string to buffer*/
MessageBoxA (NULL, str, "Debug Message", 
MB_ICONINFORMATION | MB_OK);
va_end (argptr);/* Close va_ functions*/
}

最新文章

  1. osgi笔记
  2. Could not synchronize database state with session
  3. 分组背包——sicily 1750
  4. JS不用通过其他转换两个小数加减得到正确答案
  5. JDK1.7 HashMap 源码分析
  6. 通过Sysprep封装系统
  7. I - Control - HDU 4289 (最大流)
  8. HDU 2089 不要62(挖个坑=-=)
  9. [FindBugs分析记录]Class defines clone() but doesn&#39;t implement Cloneable
  10. mysql5.1 有什么新特性
  11. (Problem 7)10001st prime
  12. 虚拟机安装中文Fedora14和C/C++IDE开发环境
  13. php websocket聊天室
  14. 关于 asp.net 点击确定按钮 获取不到新值问题
  15. ibatis 数据库时间 插入数据
  16. ASP.NET Core的实时库: SignalR -- 预备知识
  17. git总结二、关于分支上——好好认识下分支是怎么回事
  18. k-近邻(KNN)算法改进约会网站的配对效果[Python]
  19. QT 定时器详解
  20. java生成word

热门文章

  1. HDOJ 3790 双权值Dijkstra
  2. 基于visual Studio2013解决C语言竞赛题之0903文件读写
  3. 怎样在android实现uc和墨迹天气那样的左右拖动效果
  4. Android使用学习之画图(Canvas,Paint)与手势感应及其应用(乒乓球小游戏)
  5. Light OJ 1318 Strange Game 组合数+高速幂+分解因子
  6. cocos2d-x游戏开发系列教程-坦克大战游戏之虚拟手柄控制坦克移动
  7. cocos2d-x游戏开发系列教程-坦克大战游戏之坦克的显示
  8. 基于visual Studio2013解决面试题之0902内存拷贝
  9. 【Unity技巧】使用单例模式Singleton
  10. php的var关键字