DMP文件的生成和使用

来自:http://www.cnblogs.com/hanf/archive/2009/12/16/1625575.html

1.minidump.h


#include <stdio.h>
#include <windows.h>
#include <dbghelp.h>

#pragma comment(lib, "Dbghelp.lib")

LONG WINAPI MyUnhandledFilter(struct _EXCEPTION_POINTERS *lpExceptionInfo)
{
LONG ret = EXCEPTION_EXECUTE_HANDLER;

TCHAR szFileName[64];
SYSTEMTIME st;
::GetLocalTime(&st);
wsprintf(szFileName, TEXT("%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 = ::CreateFile(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)
   {
    printf("Create Dump File Success!\n");
   }
   else
   {
    printf("MiniDumpWriteDump Failed: %d\n", GetLastError());
   }

   ::CloseHandle(hFile);
}
else
{
   printf("Create File %s Failed %d\n", szFileName, GetLastError());
}
return ret;
}

 

2 调用:

 

int main()
{
::SetUnhandledExceptionFilter(MyUnhandledFilter);
int *p;
*p = 100;
return 0;
}

3.调试dump文件

  把dmp文件和exe, pdb文件放在同一目录下, 然后用编译器(如vc)打开, 然后开始调试(F5进入调试)就会中断到刚才中断的地方.

在基于对话框的程序测试

vc2008 Release生成dmp遇到以下问题:

vc2008 Release生成dmp,是要在工程属性里设置那些参数
以下设置无效:
在release模式下,修改 “项目->属性->配置属性->C/C++->优化->优化”  为 “禁用”,即可以调试。 
debug版本 已经可以产生 dmp
解决方法:
C/C++--》general-->debug Information format : Program Database for edit & continue(/ZI) 
出现错误:
cl : Command line error D8016 : '/GL' and '/ZI' command-line options are incompatible 
解决方法:
C/C++--》Optimization-->Whole Program Optimization :Enable link-time code generation(/GL) 改为 :"NO"
编译通过,但无法生成DMP文件
解决办法:
Linker-->Debugging-->Generate Debug Info: Yes(/DEBUG)
以上步骤在新建的控制台程序debug、Release中测试通过,
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值