#include <iostream>
#include<cmath>
namespace mem
{
std::string IntToHexa(int num)
{
int values[2];
int rest;
for(int i = 0; i < 2; i++)
{
rest = num % 16;
if(rest == 0 && num > 0)
{
values[i] = num/16;
}else{
values[i] = num % 16;
}
num -= values[i] * std::pow(16, i);
if(values[i] > 9)
{
values[i] = 65 + values[i] - 10;
}
}
std::string output;
for(int i = 1; i > -1; i--)
{
if(values[i] > 10)
{
output += char(values[i]);
}else{
output += std::to_string(values[i]);
}
}
return output;
}
template<typename POINTER>
void MemView(POINTER pointer, int length = 10, int lines = 1)
{
unsigned char* ptr= (unsigned char*)pointer;
for(int x = 0; x < lines; x++)
{
std::cout << (void*)ptr << " ";
for(int i = 0; i < length; i++)
{
std::cout << IntToHexa((int)*ptr) << " ";
ptr++;
}
std::cout << std::endl;
}
}
}
那么你该如何使用它呢?调用MemView函数MemView(POINTER pointer, int length = 10, int lines = 1)。第一个参数是一个指针(非函数指针)。第二个参数是一行中显示多少字节(从开始处设置为10)。最后一个参数是应该打印多少林斯(从开始处设置为1)(第二个参数设置了多少字节)。举个例子!
int main()
{
int a = 10;
int* ptr = &a;
mem::MemView(ptr);
}
输出:0x7ffee0a7a6ec 0A 00 00 00 00 A7 A7 2E FE 7F内存是以十六进制写的,这意味着每一对都是一个字节。这是从堆栈中取出的,因此顺序是相反的。因为int是4个字节(0A 00 00 00),而且顺序是相反的,所以你可以看到(00 00 00 0A)的值是10,这是a的值。另一个例子!
int main()
{
int a = 10;
int* ptr = &a;
mem::MemView(ptr, 4, 2);
}
输出:
0x7ffee4bec6ec 0A 00 00 00
0x7ffee4bec6f0 00 C7 BE E4
4条答案
按热度按时间ulydmbyx1#
第一次提出这个问题时,反汇编视图和内存查看器都不可用。
2021年7月发布了反汇编视图,可以通过点击编辑器上下文菜单中的“打开反汇编视图”来打开,通用C++调试器都支持这一点,LLDB调试器有一个“切换反汇编”命令,效果相当不错。
2022年2月,内存视图在VS Code中发布,可以通过悬停在“Variables”视图中的变量上来访问。目前仅在LLDB C++ debugger中支持此功能。
yzckvree2#
到目前为止(2018年2月),这个功能似乎还没有进入VSCode。但是,可以在VSCode调试控制台中使用-exec命令来运行GDB命令。请参见https://code.visualstudio.com/docs/languages/cpp#_gdb-lldb-and-mi-commands-gdblldb
GDB examine命令“x”以各种格式显示内存。
-exec x/64b 0x74ae70
将显示从0x 74 ae 70开始的64个十六进制字节。有关详细信息,请参阅https://sourceware.org/gdb/onlinedocs/gdb/Memory.html。
ruoxqz4g3#
当时(2020年6月),VS代码link (and maybe the answer you are looking for)中似乎还没有这个特性,但我们是编码者,可以做自己的特性;)。我是相当新的c++,所以这段代码可能不是很好,但它的工作,这是重要的一部分。代码到内存视图:
那么你该如何使用它呢?调用MemView函数
MemView(POINTER pointer, int length = 10, int lines = 1)
。第一个参数是一个指针(非函数指针)。第二个参数是一行中显示多少字节(从开始处设置为10)。最后一个参数是应该打印多少林斯(从开始处设置为1)(第二个参数设置了多少字节)。举个例子!输出:
0x7ffee0a7a6ec 0A 00 00 00 00 A7 A7 2E FE 7F
内存是以十六进制写的,这意味着每一对都是一个字节。这是从堆栈中取出的,因此顺序是相反的。因为int是4个字节(0A 00 00 00),而且顺序是相反的,所以你可以看到(00 00 00 0A)的值是10,这是a的值。另一个例子!输出:
现在,当第二个参数为4时,每行包含4个字节。因为第三个参数设置为2,所以有2行。在每行的开头,显示指向第一个字节的指针。(下一行的第一个字节是下一个字节到第一行的最后一个字节).这个程序几乎将每一个指针类型都工作,例如int,char,double...然而,它不适用于函数指针(尝试,您将得到错误)。
y1aodyip4#
VSCode 1.59中的预览功能即将推出(2021年7月)
预览功能:反汇编视图
由于C团队贡献了大量代码,我们很高兴在此里程碑中包含了反汇编视图的预览。
“反汇编”视图可以从编辑器的上下文菜单中打开,以显示活动堆栈帧的反汇编源代码,并且它支持单步执行汇编指令和在各个指令上设置断点。
“反汇编”视图仅在活动调试会话中以及基础调试扩展支持时可用。
到目前为止,只有“C”和“Mock Debug”扩展可以提供“反汇编”视图。
从技术的Angular 来看,VS代码的反汇编视图实现现在支持调试适配器协议的另外四个功能:
instructionPointerReference
属性,setInstructionBreakpoints
请求。