windows程序崩潰調(diào)試終極武器
[導(dǎo)讀]windows程序崩潰調(diào)試終極武器---dump文件一、前言前不久開發(fā)了一款windows程序,目前已經(jīng)是測試跑了,對(duì)于windows程序熟悉的童鞋,應(yīng)該都知道一個(gè)事,就是他運(yùn)行時(shí)有一個(gè)黑框,如果崩潰的就是下面這種情形~這種情況有時(shí)候會(huì)給我們一種不知所措的感覺,看日志吧~有時(shí)候崩...
windows程序崩潰調(diào)試終極武器---dump文件
一、前言
前不久開發(fā)了一款windows程序,目前已經(jīng)是測試跑了,對(duì)于windows程序熟悉的童鞋,應(yīng)該都知道一個(gè)事,就是他運(yùn)行時(shí)有一個(gè)黑框,如果崩潰的就是下面這種情形~二、實(shí)戰(zhàn)
1、dump文件簡介
dump文件是進(jìn)程的內(nèi)存鏡像,可以吧程序的執(zhí)行狀態(tài)通過調(diào)試器保存到dump文件中;2、通過任務(wù)管理生成dump文件
首先,我們寫一段測試程序:#include?
using?namespace?std;
void?fun(int*?p)
{
?p[0]?=?1;
}
int?main()
{
?fun(NULL);
?return?0;
}
然后我們編譯一把,再運(yùn)行我們會(huì)得到這么一個(gè)錯(cuò)誤:vs2015由于我吧dmp文件放在了exe和dpb目錄下,不用設(shè)置符號(hào)路徑3、通過程序生成dump文件
上面我們說到了通過任務(wù)管理器生成的dump文件的方式會(huì)出現(xiàn)不兼容或者說是錯(cuò)誤,那么怎么去解決這個(gè)問題呢?還好微軟也提供了API出來,我們可以再程序中使用微軟的API進(jìn)行調(diào)用,這樣通過程序產(chǎn)生的dump文件就沒有位數(shù)的問題了;這里提供一個(gè)通用的代碼,是直接可以拿過來用的~感覺我吧minidmp.h
#pragma?once
#include?
#include?
#include?
#pragma?comment(lib,?"dbghelp.lib")
#pragma?warning(disable:4996)?//全部關(guān)掉
#pragma?warning(once:4996)?//僅顯示一個(gè)
/*
#ifndef?_M_IX86
#error?"The?following?code?only?works?for?x86!"
#endif
*/
inline?BOOL?IsDataSectionNeeded(const?WCHAR*?pModuleName)
{
?if?(pModuleName?==?0)
?{
??return?FALSE;
?}
?WCHAR?szFileName[_MAX_FNAME]?=?L"";
?_wsplitpath(pModuleName,?NULL,?NULL,?szFileName,?NULL);
?if?(wcsicmp(szFileName,?L"ntdll")?==?0)
??return?TRUE;
?return?FALSE;
}
inline?BOOL?CALLBACK?MiniDumpCallback(PVOID????????????????????????????pParam,
?const?PMINIDUMP_CALLBACK_INPUT???pInput,
?PMINIDUMP_CALLBACK_OUTPUT????????pOutput)
{
?if?(pInput?==?0?||?pOutput?==?0)
??return?FALSE;
?switch?(pInput->CallbackType)
?{
?case?ModuleCallback:
??if?(pOutput->ModuleWriteFlags? 




