windows 下C++生成Dump調(diào)試文件與分析
1、前言
dump文件是C++程序發(fā)生異常時(shí),保存當(dāng)時(shí)程序運(yùn)行狀態(tài)的文件,是調(diào)試異常程序重要的方法,所以程序崩潰時(shí),除了日志文件,dump文件便成了我們查找錯誤的最后一根救命的稻草。
2、依賴庫下載
生成dump需要有Dbghelp的庫,正常來說VS、qt都自帶了。如果沒有,私信我發(fā)你。
3、項(xiàng)目配置
3.1、設(shè)置輸出路徑
步驟:右擊項(xiàng)目-》屬性-》配置屬性-》常規(guī) -》輸出路徑

設(shè)置一個固定的輸出路徑,是為了方便存放deghelp.dll動態(tài)庫。

3.2、拷貝依賴資源
1、將頭文件拷貝至和main.cpp同級。

2、將dbghelp.lib靜態(tài)庫、dbghelp.dll動態(tài)庫拷貝至輸出目錄下(如果沒有輸出目錄,請先運(yùn)行一遍程序即可)

3.3 將dbghelp.h添加在工程中
步驟:右擊頭文件目錄-》點(diǎn)擊添加-》現(xiàn)有項(xiàng)

3.4、配置lib文件路徑
步驟:右擊項(xiàng)目-》屬性-》配置屬性-》鏈接器 -》輸入-》附加依賴項(xiàng) 輸入dbghelp.lib

3.5、添加生成minidump文件方法
在main.cpp中添加MyUnhandledExceptionFilter方法。然后在main函數(shù)的開頭添加SetUnhandledExceptionFilter(MyUnhandledExceptionFilter);代碼。
#include <windows.h>
#include <Dbghelp.h>
LONG WINAPI MyUnhandledExceptionFilter(struct _EXCEPTION_POINTERS* ExceptionInfo)
{
HANDLE lhDumpFile = CreateFile(L".\\bin_D\\miniDumpFile.dmp", GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
MINIDUMP_EXCEPTION_INFORMATION loExceptionInfo;
loExceptionInfo.ExceptionPointers = ExceptionInfo;
loExceptionInfo.ThreadId = GetCurrentThreadId();
loExceptionInfo.ClientPointers = TRUE;
MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), lhDumpFile, MiniDumpNormal, &loExceptionInfo, NULL, NULL);
CloseHandle(lhDumpFile);
return EXCEPTION_EXECUTE_HANDLER;
}
int main()
{
SetUnhandledExceptionFilter(MyUnhandledExceptionFilter);
//....
return 0;
}
4、測試效果
在main中添加下面的代碼,然后運(yùn)行,將會在工作路徑下看到miniDumpFile.dmp文件
int test(int a, int b)
{
return a / b;
}
int main()
{
SetUnhandledExceptionFilter(MyUnhandledExceptionFilter);
int a = 1;
int b = 0;
std::cout << test(a, b) << std::endl;
//....
return 0;
}見下圖。

5、打開dump文件進(jìn)行定位
有VS的情況下,可以直接雙擊xx.dmp文件。然后點(diǎn)擊右側(cè)的【僅限本機(jī)調(diào)試】

然后我們就可以看到程序崩潰的位置,這時(shí)我們還可以查看堆棧、內(nèi)存的信息。加快排查錯誤。

到此這篇關(guān)于windows 下C++生成Dump調(diào)試文件與分析的文章就介紹到這了,更多相關(guān)C++生成Dump調(diào)試文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談C語言中的sizeof()和strlen()的區(qū)別
本文主要介紹了C語言中的sizeof()和strlen()的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
C++ Custom Control控件向父窗體發(fā)送對應(yīng)的消息
這篇文章主要介紹了C++ Custom Control控件向父窗體發(fā)送對應(yīng)的消息的相關(guān)資料,需要的朋友可以參考下2015-06-06
用C# 控制Windows系統(tǒng)音量的實(shí)現(xiàn)方法
本篇文章是對使用C#控制Windows系統(tǒng)音量的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C語言光標(biāo)信息CONSOLE_CURSOR_INFO類型詳解
本文詳細(xì)講解了C語言光標(biāo)信息CONSOLE_CURSOR_INFO類型,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12

