3汪值 + 原创作品转载请注明出处 + 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
1)实验部分(以下命令为实验楼64位Linux虚拟机环境下适用,32位Linux环境可能会稍有不同)
使用
1. gcc –S –o main.s main.c -m32
命令编译成汇编代码,如下代码中的数字请自行修改以防与他人雷同
1. int g(int x)
2. {
3. return x + 3;
4. }
5.
6. int f(int x)
7. {
8. return g(x);
9. }
10.
11. int main(void)
12. {
13. return f(5) + 7;
14. }
源代码如图:
使用 gcc -S 命令编译成汇编代码
查看完整的汇编代码
整理过后的汇编代码
C语言源代码和汇编指令对照:
eip是控制整个程序运行过程的决定因素:
(1若遇到跳转语句(JMP 等)时,先将 eip 压栈保存,即当前指令的下一条指令的地址,然后将需要跳转的目的地址赋给 eip,实现跳转;
(2、若遇到函数调用call时,除了将 eip 压栈,还要保存当前堆栈的状态,将栈基指针 ebp 压栈,然后将相应函数地址赋给 eip,实现跳转;
(3、若为普通指令,则继续从 eip 指向的地址取出下一条指令执行。
栈在程序执行过程中发挥着至关重要的作用,栈这种特殊的数据结构为函数的调用提供了可能,使得程序的执行更加灵活、过程更加直观;也使得编程更加简单、方便;同时,只有理解栈的结构和性质,才能理解程序是如何执行的。
汪值 + 原创作品转载请注明出处 + 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000