資源簡介
#include "Stdafx.h"
#include "DebugUtility.h"
// 安全拷貝字符串函數
void SafeStrCpy0(char* szDest, size_t nMaxDestSize, const char* szSrc)
{
if (nMaxDestSize <= 0) return;
if (strlen(szSrc) < nMaxDestSize)
{
strcpy_s(szDest, nMaxDestSize, szSrc);
}
else
{
strncpy_s(szDest, nMaxDestSize, szSrc, nMaxDestSize);
szDest[nMaxDestSize - 1] = '\0';
}
}
// 得到CallStack信息
vector<CallStackInfo> GetCallStack0()
{
CONTEXT _ctx;
RtlCaptureContext(&_ctx);
const CONTEXT* pContext = &_ctx;
HANDLE hProcess = GetCurrentProcess();
SymInitialize(hProcess, NULL, TRUE);
vector<CallStackInfo> arrCallStackInfo;
CONTEXT c = *pContext;
STACKFRAME64 sf;
memset(&sf, 0, sizeof(STACKFRAME64));
DWORD dwImageType = IMAGE_FILE_MACHINE_I386;
// 不同的CPU類型,具體信息可查詢MSDN
//
#ifdef _M_IX86
sf.AddrPC.Offset = c.Eip;
sf.AddrPC.Mode = AddrModeFlat;
sf.AddrStack.Offset = c.Esp;
sf.AddrStack.Mode = AddrModeFlat;
sf.AddrFrame.Offset = c.Ebp;
sf.AddrFrame.Mode = AddrModeFlat;
#elif _M_X64
dwImageType = IMAGE_FILE_MACHINE_AMD64;
sf.AddrPC.Offset = c.Rip;
sf.AddrPC.Mode = AddrModeFlat;
sf.AddrFrame.Offset = c.Rsp;
sf.AddrFrame.Mode = AddrModeFlat;
sf.AddrStack.Offset = c.Rsp;
sf.AddrStack.Mode = AddrModeFlat;
#elif _M_IA64
dwImageType = IMAGE_FILE_MACHINE_IA64;
sf.AddrPC.Offset = c.StIIP;
sf.AddrPC.Mode = AddrModeFlat;
sf.AddrFrame.Offset = c.IntSp;
sf.AddrFrame.Mode = AddrModeFlat;
sf.AddrBStore.Offset = c.RsBSP;
sf.AddrBStore.Mode = AddrModeFlat;
sf.AddrStack.Offset = c.IntSp;
sf.AddrStack.Mode = AddrModeFlat;
#else
#error "Platform not supported!"
#endif
HANDLE hThread = GetCurrentThread();
while (true)
{
// 該函數是實現這個功能的最重要的一個函數
// 函數的用法以及參數和返回值的具體解釋可以查詢MSDN
if (!StackWalk64(dwImageType, hProcess, hThread, &sf, &c, NULL, SymFunctionTableAccess64, SymGetModuleBase64, NULL))
{
break;
}
if (sf.AddrFrame.Offset == 0)
{
break;
}
CallStackInfo callstackinfo;
SafeStrCpy0(callstackinfo.MethodName, MAX_NAME_LENGTH, "N/A");
SafeStrCpy0(callstackinfo.FileName, MAX_NAME_LENGTH, "N/A");
SafeStrCpy0(callstackinfo.ModuleName, MAX_NAME_LENGTH, "N/A");
SafeStrCpy0(callstackinfo.LineNumber, MAX_NAME_LENGTH, "N/A");
BYTE symbolBuffer[sizeof(IMAGEHLP_SYMBOL64) MAX_NAME_LENGTH];
IMAGEHLP_SYMBOL64 *pSymbol = (IMAGEHLP_SYMBOL64*)symbolBuffer;
memset(pSymbol, 0, sizeof(IMAGEHLP_SYMBOL64) MAX_NAME_LENGTH);
pSymbol->SizeOfStruct = sizeof(symbolBuffer);
pSymbol->MaxNameLength = MAX_NAME_LENGTH;
DWORD symDisplacement = 0;
// 得到函數名
if (SymGetSymFromAddr64(hProcess, sf.AddrPC.Offset, NULL, pSymbol))
{
SafeStrCpy0(callstackinfo.MethodName, MAX_NAME_LENGTH, pSymbol->Name);
}
IMAGEHLP_LINE64 lineInfo;
memset(&lineInfo, 0, sizeof(IMAGEHLP_LINE64));
lineInfo.SizeOfStruct = sizeof(IMAGEHLP_LINE64);
DWORD dwLineDisplacement;
// 得到文件名和所在的代碼行
if (SymGetLineFromAddr64(hProcess, sf.AddrPC.Offset, &dwLineDisplacement, &lineInfo))
{
SafeStrCpy0(callstackinfo.FileName, MAX_NAME_LENGTH, lineInfo.FileName);
sprintf_s(callstackinfo.LineNumber, "%d", lineInfo.LineNumber);
}
IMAGEHLP_MODULE64 moduleInfo;
memset(&moduleInfo, 0, sizeof(IMAGEHLP_MODULE64));
moduleInfo.SizeOfStruct = sizeof(IMAGEHLP_MODULE64);
// 得到模塊名
if (SymGetModuleInfo64(hProcess, sf.AddrPC.Offset, &moduleInfo))
{
SafeStrCpy0(callstackinfo.ModuleName, MAX_NAME_LENGTH, moduleInfo.ModuleName);
}
arrCallStackInfo.push_back(callstackinfo);
}
SymCleanup(hProcess);
return arrCallStackInfo;
}
#include "DebugUtility.h"
// 安全拷貝字符串函數
void SafeStrCpy0(char* szDest, size_t nMaxDestSize, const char* szSrc)
{
if (nMaxDestSize <= 0) return;
if (strlen(szSrc) < nMaxDestSize)
{
strcpy_s(szDest, nMaxDestSize, szSrc);
}
else
{
strncpy_s(szDest, nMaxDestSize, szSrc, nMaxDestSize);
szDest[nMaxDestSize - 1] = '\0';
}
}
// 得到CallStack信息
vector<CallStackInfo> GetCallStack0()
{
CONTEXT _ctx;
RtlCaptureContext(&_ctx);
const CONTEXT* pContext = &_ctx;
HANDLE hProcess = GetCurrentProcess();
SymInitialize(hProcess, NULL, TRUE);
vector<CallStackInfo> arrCallStackInfo;
CONTEXT c = *pContext;
STACKFRAME64 sf;
memset(&sf, 0, sizeof(STACKFRAME64));
DWORD dwImageType = IMAGE_FILE_MACHINE_I386;
// 不同的CPU類型,具體信息可查詢MSDN
//
#ifdef _M_IX86
sf.AddrPC.Offset = c.Eip;
sf.AddrPC.Mode = AddrModeFlat;
sf.AddrStack.Offset = c.Esp;
sf.AddrStack.Mode = AddrModeFlat;
sf.AddrFrame.Offset = c.Ebp;
sf.AddrFrame.Mode = AddrModeFlat;
#elif _M_X64
dwImageType = IMAGE_FILE_MACHINE_AMD64;
sf.AddrPC.Offset = c.Rip;
sf.AddrPC.Mode = AddrModeFlat;
sf.AddrFrame.Offset = c.Rsp;
sf.AddrFrame.Mode = AddrModeFlat;
sf.AddrStack.Offset = c.Rsp;
sf.AddrStack.Mode = AddrModeFlat;
#elif _M_IA64
dwImageType = IMAGE_FILE_MACHINE_IA64;
sf.AddrPC.Offset = c.StIIP;
sf.AddrPC.Mode = AddrModeFlat;
sf.AddrFrame.Offset = c.IntSp;
sf.AddrFrame.Mode = AddrModeFlat;
sf.AddrBStore.Offset = c.RsBSP;
sf.AddrBStore.Mode = AddrModeFlat;
sf.AddrStack.Offset = c.IntSp;
sf.AddrStack.Mode = AddrModeFlat;
#else
#error "Platform not supported!"
#endif
HANDLE hThread = GetCurrentThread();
while (true)
{
// 該函數是實現這個功能的最重要的一個函數
// 函數的用法以及參數和返回值的具體解釋可以查詢MSDN
if (!StackWalk64(dwImageType, hProcess, hThread, &sf, &c, NULL, SymFunctionTableAccess64, SymGetModuleBase64, NULL))
{
break;
}
if (sf.AddrFrame.Offset == 0)
{
break;
}
CallStackInfo callstackinfo;
SafeStrCpy0(callstackinfo.MethodName, MAX_NAME_LENGTH, "N/A");
SafeStrCpy0(callstackinfo.FileName, MAX_NAME_LENGTH, "N/A");
SafeStrCpy0(callstackinfo.ModuleName, MAX_NAME_LENGTH, "N/A");
SafeStrCpy0(callstackinfo.LineNumber, MAX_NAME_LENGTH, "N/A");
BYTE symbolBuffer[sizeof(IMAGEHLP_SYMBOL64) MAX_NAME_LENGTH];
IMAGEHLP_SYMBOL64 *pSymbol = (IMAGEHLP_SYMBOL64*)symbolBuffer;
memset(pSymbol, 0, sizeof(IMAGEHLP_SYMBOL64) MAX_NAME_LENGTH);
pSymbol->SizeOfStruct = sizeof(symbolBuffer);
pSymbol->MaxNameLength = MAX_NAME_LENGTH;
DWORD symDisplacement = 0;
// 得到函數名
if (SymGetSymFromAddr64(hProcess, sf.AddrPC.Offset, NULL, pSymbol))
{
SafeStrCpy0(callstackinfo.MethodName, MAX_NAME_LENGTH, pSymbol->Name);
}
IMAGEHLP_LINE64 lineInfo;
memset(&lineInfo, 0, sizeof(IMAGEHLP_LINE64));
lineInfo.SizeOfStruct = sizeof(IMAGEHLP_LINE64);
DWORD dwLineDisplacement;
// 得到文件名和所在的代碼行
if (SymGetLineFromAddr64(hProcess, sf.AddrPC.Offset, &dwLineDisplacement, &lineInfo))
{
SafeStrCpy0(callstackinfo.FileName, MAX_NAME_LENGTH, lineInfo.FileName);
sprintf_s(callstackinfo.LineNumber, "%d", lineInfo.LineNumber);
}
IMAGEHLP_MODULE64 moduleInfo;
memset(&moduleInfo, 0, sizeof(IMAGEHLP_MODULE64));
moduleInfo.SizeOfStruct = sizeof(IMAGEHLP_MODULE64);
// 得到模塊名
if (SymGetModuleInfo64(hProcess, sf.AddrPC.Offset, &moduleInfo))
{
SafeStrCpy0(callstackinfo.ModuleName, MAX_NAME_LENGTH, moduleInfo.ModuleName);
}
arrCallStackInfo.push_back(callstackinfo);
}
SymCleanup(hProcess);
return arrCallStackInfo;
}
代碼片段和文件信息
#include?“Stdafx.h“
#include?“DebugUtility.h“
//?安全拷貝字符串函數????
void?SafeStrCpy0(char*?szDest?size_t?nMaxDestSize?const?char*?szSrc)
{
if?(nMaxDestSize?<=?0)?return;
if?(strlen(szSrc)? {
strcpy_s(szDest?nMaxDestSize?szSrc);
}
else
{
strncpy_s(szDest?nMaxDestSize?szSrc?nMaxDestSize);
szDest[nMaxDestSize?-?1]?=?‘\0‘;
}
}
//?得到CallStack信息????
vector?GetCallStack0()
{
CONTEXT?_ctx;
RtlCaptureContext(&_ctx);
const?CONTEXT*?pContext?=?&_ctx;
HANDLE?hProcess?=?GetCurrentProcess();
SymInitialize(hProcess?NULL?TRUE);
vector?arrCallStackInfo;
CONTEXT?c?=?*pContext;
STACKframe64?sf;
memset(&sf?0?sizeof(STACKframe64));
DWORD?dwImageType?=?IMAGE_FILE_MACHINE_I386;
//?不同的CPU類型,具體信息可查詢MSDN????
//????
#ifdef?_M_IX86????
sf.AddrPC.Offset?=?c.Eip;
sf.AddrPC.Mode?=?AddrModeFlat;
sf.AddrStack.Offset?=?c.Esp;
sf.AddrStack.Mode?=?AddrModeFlat;
sf.Addrframe.Offset?=?c.Ebp;
?屬性????????????大小?????日期????時間???名稱
-----------?---------??----------?-----??----
?????文件????????3772??2017-12-20?12:21??DebugUtility.cpp
?????文件?????????717??2017-12-21?15:41??DebugUtility.h
評論
共有 條評論
相關資源
- windows文件夾監控(c++源碼)
- C++ tts開發 可調節語速,音量,切換語
- CSA算法MATLAB代碼
- zprotect 1.6 脫殼工具()
- DDC/CI Tool
- PLCWin10ActiveXTest(三菱PLC通訊控件)
- FTP客戶端源代碼C語言
- c++(3_MSGS.C)
- 實現圖像實時采集(使用BaslerSDK)-
- directx實現正方體圖片映射
- c++實現P2PDemo(點對點聊天)
- CVR100UD身份證閱讀器二次開發SDK開發說
- windows 串口升級工具(c++源碼)
- ntmedsys.sys(c++源碼)
- 一款MFC關機小程序
- 自制操作系統.docx(附源碼地址)
- 操作系統原理及設計原則(Operating
- 基于51單片機的音樂播放器設計.doc
- 基于C的圖書管理系統 畢業設計
- com 原理應用源碼
- DSS中的RTSPclientLib程序
- 完成端口開發包iocpmfc
- c 常用的數據結構 (Errata for Ford/Top
- RTSPRTP C++ 源代碼
-
c++ xm
lRPC - tftpd32 源代碼VC
- 《Learning WebRTC》pdf 高清
- Windows Sockets 規范及應用-Windows網絡編
- httpserver(SuperCookie)
- C語言基數排序——順序隊列實現