1. 程式人生 > >vc++ 開發的程式不定時崩潰怎麼定位?minidump 來幫你

vc++ 開發的程式不定時崩潰怎麼定位?minidump 來幫你

vc++ 開發的程式不定時崩潰怎麼定位?minidump 來幫你

 

在程式開始的地方設定結構化異常處理函式

//Add UnhandledExceptionFilter;
	SetUnhandledExceptionFilter(CrashUnhandledExceptionFilter);

在異常處理函式中自己寫minidump

LONG WINAPI CrashUnhandledExceptionFilter(_EXCEPTION_POINTERS* lpExceptionInfo)
{
	TCHAR szProgramPath[MAX_PATH] = { 0 };
	if (GetModuleFileName(NULL, szProgramPath, MAX_PATH))
	{
		LPTSTR lpSlash = _tcsrchr(szProgramPath, _T('//'));
		if (lpSlash)
		{
			*(lpSlash + 1) = _T('/0');
		}
	}

	TCHAR szDumpFile[MAX_PATH*4] = { 0 };
	_stprintf_s(szDumpFile, MAX_PATH * 4 -1, _T("%s%d.dmp"), szProgramPath, time(NULL));

	HANDLE hDumpFile = CreateFile(szDumpFile, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
	MINIDUMP_EXCEPTION_INFORMATION stMiniDumpExceptionInfo;
	stMiniDumpExceptionInfo.ExceptionPointers = lpExceptionInfo;
	stMiniDumpExceptionInfo.ThreadId = GetCurrentThreadId();
	stMiniDumpExceptionInfo.ClientPointers = TRUE;
	MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hDumpFile,
		MiniDumpNormal, (lpExceptionInfo) ? &stMiniDumpExceptionInfo : NULL, NULL, NULL);
	CloseHandle(hDumpFile);

	MessageBox(NULL, _T("Program crashed, generate dump file!"), _T("Notice"), MB_OK);
	return EXCEPTION_EXECUTE_HANDLER;
}

 

接著寫一個可以崩潰的函式

void MytestCrash()
{
	TCHAR* pszinfo = NULL;
	ZeroMemory(pszinfo, 1);
}

 

這樣程式崩潰的時候就有dump出來了

 

有了dump 就可以使用神器Windbg來分析了

設定要pdb 跟source code的路徑

輸入 !analyze -v命令 即可顯示出結果,甚至定位到原始碼出問題的那一行

不過前提是你的堆疊破壞的不夠嚴重