来自: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)