http://blog.163.com/strive_only/blog/static/89380168201192894043752/
首先编写一个C语言程序code.c,包含的过程定义如下:
int accum = 0; int sum (int x, int y) { int t = x+y; accum +=t; return t; } |
使用“-c”命令行选项,GCC会编译汇编该代码:
(gdb) x/17xb sum
告诉GDB检查(简写为x)17个十六进制格式的字节(简写为b)
unix>objdump -d code.o
结果如下:
值得注意,反汇编器使用的指令命名规则与GCC生成的汇编代码使用的有些细微的差别。上面示例中,省略了很多指令结尾的“l”。这些后缀是大小指示符,大多情况下可以忽略。
int main() { return sum(1, 3); } |
unix>objdump -d prog
反汇编器会抽取出各种代码序列,包括下面这个段:
这段代码与code.c反汇编生成的几乎完全一样。其中一个主要区别是櫣列出的地址不同——链接器将代码的地址移到一段不同的地址范围中。第二个不同之处在于链接器确定了存储全局变量accum的地址。