出自计组第三次上机附加题第二题
用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:8
8 printf(format, &magic);
接下来就要查看内存了
gdb中查看内存的方法总结:
使用examine命令(简写是x)来查看内存地址中的值。x命令的语法如下:
x/<n/f/u><addr>
n、f、u是可选的参数。
n 是一个正整数, 表示显示内存的长度 ,也就是说从当前地址向后显示几个地址的内容。
f 表示显示的格式 ,参见上面。如果地址所指的是 字符串 ,那么格式可以是 s ,如果 地址是指令 地址 ,那么格式可以是 i 。
u 表示从当前地址往后请求的字节数,如果不指定的话,GDB默认是4个bytes 。 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的地址