vs 调试方法总结

2 篇文章 0 订阅

分类概述

本机断点调试,debug

本机打印信息调试(通过添加控制台或日志),release、debug均可

远程局域网msvsmon.exe调试,debug

发行版崩溃dump调试(两种)release

上面两种不再介绍,本文介绍后面两种

远程局域网msvsmon.exe调试

该方式主要用于检测程序对不同系统的兼容性。

项目设置及编译(生成调试需要的exe、lib、dll和pdb文件),按照如下设置

从vs安装目录(..\Common7\IDE\Remote Debugger)拷贝文件夹到调试机,需要对应相应程序的编译版本

在调试机打开(如x86)下的msvsmon.exe,进行设置,在工具里设置

在调试机上,将编译好的程序和pdb放在一起(确保程序和pdb是一起编译的,debug模式)

在安装vs的机器上打开生成程序的项目,在代码中设置断点,可以利用(弹出框,getchar()),确保程序能进入断点。

在以下位置设置远程调试方法,限定符写入调试机ip,如:192.168.1.110:4020,选择可用进程里需要调试的程序,最后点击附加。即可像本机断点调试一样,调试远程程序

 

dump调试

dump调试有两种,第一种:在程序中加入代码,程序崩溃时会生成.dmp文件(非文本文件),第二种:通过VS设置,程序崩溃时生成.dmp文件(文本文件),两种方式都需要pdb文件(release模式下的pdb)。

第一种

在程序中添加代码如下

#include <Windows.h>
#include <DbgHelp.h>

using namespace std;


int GenerateMiniDump(PEXCEPTION_POINTERS pExceptionPointers)
{
	// 定义函数指针
	typedef BOOL(WINAPI * MiniDumpWriteDumpT)(
		HANDLE,
		DWORD,
		HANDLE,
		MINIDUMP_TYPE,
		PMINIDUMP_EXCEPTION_INFORMATION,
		PMINIDUMP_USER_STREAM_INFORMATION,
		PMINIDUMP_CALLBACK_INFORMATION
		);
	// 从 "DbgHelp.dll" 库中获取 "MiniDumpWriteDump" 函数
	MiniDumpWriteDumpT pfnMiniDumpWriteDump = NULL;
	HMODULE hDbgHelp = LoadLibrary(_T("DbgHelp.dll"));
	if (NULL == hDbgHelp)
	{
		return EXCEPTION_CONTINUE_EXECUTION;
	}
	pfnMiniDumpWriteDump = (MiniDumpWriteDumpT)GetProcAddress(hDbgHelp, "MiniDumpWriteDump");

	if (NULL == pfnMiniDumpWriteDump)
	{
		FreeLibrary(hDbgHelp);
		return EXCEPTION_CONTINUE_EXECUTION;
	}
	// 创建 dmp 文件件
	TCHAR szFileName[MAX_PATH] = { 0 };
	TCHAR* szVersion = _T("DumpDemo_v1.0");
	SYSTEMTIME stLocalTime;
	GetLocalTime(&stLocalTime);
	wsprintf(szFileName, L"%s-%04d%02d%02d-%02d%02d%02d.dmp",
		szVersion, stLocalTime.wYear, stLocalTime.wMonth, stLocalTime.wDay,
		stLocalTime.wHour, stLocalTime.wMinute, stLocalTime.wSecond);
	HANDLE hDumpFile = CreateFile(szFileName, GENERIC_READ | GENERIC_WRITE,
		FILE_SHARE_WRITE | FILE_SHARE_READ, 0, CREATE_ALWAYS, 0, 0);
	if (INVALID_HANDLE_VALUE == hDumpFile)
	{
		FreeLibrary(hDbgHelp);
		return EXCEPTION_CONTINUE_EXECUTION;
	}
	// 写入 dmp 文件
	MINIDUMP_EXCEPTION_INFORMATION expParam;
	expParam.ThreadId = GetCurrentThreadId();
	expParam.ExceptionPointers = pExceptionPointers;
	expParam.ClientPointers = FALSE;
	pfnMiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(),
		hDumpFile, MiniDumpWithDataSegs, (pExceptionPointers ? &expParam : NULL), NULL, NULL);
	// 释放文件
	CloseHandle(hDumpFile);
	FreeLibrary(hDbgHelp);
	return EXCEPTION_EXECUTE_HANDLER;
}

LONG WINAPI ExceptionFilter(LPEXCEPTION_POINTERS lpExceptionInfo)
{
	// 这里做一些异常的过滤或提示
	if (IsDebuggerPresent())
	{
		return EXCEPTION_CONTINUE_SEARCH;
	}
	return GenerateMiniDump(lpExceptionInfo);
}

调试代码如下

void func(string strRet)
{
	printf("%s", strRet.c_str());
	
}

int main()
{
	SetUnhandledExceptionFilter(ExceptionFilter);
	func(NULL);
	getchar();
    return 0;
}

SetUnhandledExceptionFilter需在程序最开始位置

生成的exe运行会直接退出,func(NULL);

在exe所在目录下生成.dmp文件,将文件拖拽到vs中,点击“使用 仅限本机 进行调试",出现堆栈调试如下,准确定位崩溃位置

第二种

忘了如何设置的,先介绍下效果。后续会补充,如果哪位朋友知道,望告知。

通过vs设置,生成pdb;在exe所在目录下创建一个dmp文件(文本的,崩溃信息会记录在该文件中),文件内容是文本模式的堆栈信息,包含代码行,变量,函数,值等,很详细。可直接通过文件确认程序崩溃的位置。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值