有时,在我们的程序运行的时候,会遇到一些崩溃问题,尤其是概率出现的时候,如果能捕获其异常,那么对于我们快速定位bug是很有帮助的
这里借用网上搜寻回来的函数,记录一下:
头文件及库:
#include <dbghelp.h>
#pragma comment ( lib, "dbghelp.lib" )
wstring GetPresentTime()
{
SYSTEMTIME time;
GetLocalTime(&time); TCHAR wszTime[];
swprintf_s(wszTime, _T("%04d-%02d-%02d %02d-%02d-%02d-%03d"), time.wYear, time.wMonth, time.wDay, time.wHour, time.wMinute, time.wSecond, time.wMilliseconds); return wstring(wszTime);
} void CreateDumpFile(LPCWSTR lpstrDumpFilePathName, EXCEPTION_POINTERS *pException)
{
// 创建Dump文件
//
HANDLE hDumpFile = CreateFile(lpstrDumpFilePathName, GENERIC_WRITE, , NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); // Dump信息
//
MINIDUMP_EXCEPTION_INFORMATION dumpInfo;
dumpInfo.ExceptionPointers = pException;
dumpInfo.ThreadId = GetCurrentThreadId();
dumpInfo.ClientPointers = TRUE; // 写入Dump文件内容
//
MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hDumpFile, MiniDumpNormal, &dumpInfo, NULL, NULL); CloseHandle(hDumpFile);
} LONG CallBackCrashHandler(EXCEPTION_POINTERS *pException)
{
MessageBox(NULL,L"你的程序 遇到一个错误,已停止运行,请重新启动",L"错误",MB_OK); // 以当前时间为文件名
//
TCHAR szModuleDir[];
DWORD dwLength=GetModuleFileName(NULL,szModuleDir,); for(DWORD dw=dwLength-;dw>;dw--)
{
if(szModuleDir[dw]=='\\')
{
szModuleDir[dw+]=;
break;
}
} wstring strDumpFileName = szModuleDir + GetPresentTime() +_T(".dmp"); // 创建Dump文件
//
CreateDumpFile(strDumpFileName.data(), pException); return EXCEPTION_EXECUTE_HANDLER;
}
调用:
SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)CallBackCrashHandler);
也许有些bug不能抓到,例如刚开始的一些初始化信息时的异常,不过大部分还是可以的
会提供小小的帮助。