gdb中查看内存方法总结

时间:2022-03-13 09:22:35

出自计组第三次上机附加题第二题

用gdb运行程序b,输出中相应地址究竟指向了什么?
请贴上你是如何找到的(使用了什么gdb指令等等)

gdb中查看内存方法总结gdb中查看内存方法总结gdb中查看内存方法总结gdb中查看内存方法总结gdb中查看内存方法总结

gdb中查看内存方法总结

在查看地址前首先需要断点定位到需要查看的位置

显示代码内容

(gdb) l

在第八行设置断点

(gdb) break 8

运行

(gdb) run

将会在断点处停下

Starting program: /Users/xujiaxing/Downloads/lab3_补充题目/b/b/b
[New Thread 0x1e03 of process 905]
warning: unhandled dyld version (15)

Thread 2 hit Breakpoint 1, main () at b.c:8
8 printf(format, &magic);


接下来就要查看内存了

 

gdb中查看内存的方法总结:

使用examine命令(简写是x)来查看内存地址中的值。x命令的语法如下:

x/<n/f/u><addr>

n、f、u是可选的参数。

n 是一个正整数, 表示显示内存的长度 ,也就是说从当前地址向后显示几个地址的内容。
f 表示显示的格式 ,参见上面。如果地址所指的是 字符串 ,那么格式可以是 s ,如果 地址是指令 地址 ,那么格式可以是 i
u 表示从当前地址往后请求的字节数,如果不指定的话,GDB默认是4bytes u 参数可以用下面的字符来代替, b 表示单字节, h 表示双字节, w 表示四字 节, g 表示八字节。当我们指定了字节长度后, GDB 会从指内存定的内存地址开始,读写指定字节,并把其当作一个值取出来。

<addr>
表示一个内存地址。
n/f/u
三个参数可以一起使用。例如:

命令: x/3uh 0x54320 表示,从内存地址 0x54320读取内容, h表示以双字节为一个单位, 3表示三个单位, u表示按十六进制显示。

输出格式
一般来说,GDB会根据变量的类型输出变量的值。但你也可以自定义GDB的输出的格式。例如,你想输出一个整数的十六进制,或是二进制来查看这个整型变量的中的位的情况。要做到这样,你可以使用GDB的数据显示格式:

x 按十六进制格式显示变量。
d
按十进制格式显示变量。
u
按十六进制格式显示无符号整型。
o
按八进制格式显示变量。
t
按二进制格式显示变量。
a
按十六进制格式显示变量。
c
按字符格式显示变量。
f
按浮点数格式显示变量。

 

所以查看十进制地址的方法即为:

(gdb) x/9db 0x00001fa4

从内存地址0x00001fa4读取内容,b表示以单字节为一个单位,9表示九个单位,d表示按十进制显示。

 

还有另外一种方法是直接print,由于0xBFFFFAA0是指针的指针所指向的地址,所以查看其内容即为

(gdb) p/d**(char**) 0xBFFFFAA0@9

从内存地址0xBFFFFAA0读取内容,d表示以十进制显示,@9表示读取一片连续的长度为9的地址