gdb中查看内存方法总结

来源:互联网 发布:剑灵不知火舞捏脸数据 编辑:程序博客网 时间:2024/06/03 20:59

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

用gdb运行程序b,输出中相应地址究竟指向了什么?请贴上你是如何找到的(使用了什么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:88        printf(format, &magic);


接下来就要查看内存了

 

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

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

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

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

n是一个正整数,表示显示内存的长度,也就是说从当前地址向后显示几个地址的内容。
f 表示显示的格式,参见上面。如果地址所指的是字符串,那么格式可以是s,如果地址是指令地址,那么格式可以是i
u 表示从当前地址往后请求的字节数,如果不指定的话,GDB默认是4bytesu参数可以用下面的字符来代替,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的地址


原创粉丝点击