前言
我们编写出来的代码只是单纯的ASCII码字符而已。其文本是不能在机器上运行的。机器只能识别机器码,也就是所谓的位串。由01组成的流控制电路的翻转,最后组成了具有逻辑意义的代码。
那么,我们很容易发现一个问题,我们写出来的高级语言的代码是怎么一步一步变成机器码,从而让机器可以执行的呢?
本文主要论述如下问题:
1. AT&T指令的基本知识
2.分支和循环的机器级实现
3. 函数的调用的机器级表示
4. 异质的数据结构大小确定问题(对齐)
基本知识
其中%esp,%ebp分别指向栈顶和栈底。其他的寄存器暂时不讨论,后续会提到。
可以看出用户栈(user stack)是从高地址向低地址增长