这一章节介绍了存储程序计算机的结构以及关于汇编的基础知识,由于之前看过re4b,所以权当复习了。
从硬件角度讲,存储程序计算机包括输入、输出、存储、计算和控制五部分。
从程序员的角度,一个程序的执行过程就是CPU不断从内存中获取指令并执行的过程。从汇编语言的角度可以比较清晰的看出计算机是如何执行程序的,当然,由于编译器以及平台的不同,使用高级语言编写的程序可能会生成不同的汇编指令,这里只针对linux 的x86系统,gcc编译器。
实验过程
main.c文件:
int g(int x) {
return x + 3;
}
int f(int x) {
return g(x);
}
int main(void) {
return f(8) + 1;
}
main.s文件(处理后):
该汇编指令频繁使用了三个寄存器ebp, esp和eax。ebp是基址指针寄存器;esp是栈指针寄存器,通常指向栈顶;eax可以暂存数据,同时也作为函数返回值的默认存储位置。
从main.s文件中可以清楚的看到三个函数的汇编代码,其中有一段代码重复出现
pushl %ebp
movl %esp, %ebp
这段代码在出现在每个函数的初始部分,相当于保存现场,与函数结束时的leave指令(恢复现场)相对应。
现在对代码执行过程中的栈情况进行分析。
高级语言对计算机的工作过程进行了抽象,通过分析对应的汇编代码,可以对计算机的工作过程有一个更为清晰的认识,看似复杂的过程,实际上只是CPU与内存之间重复性的交互过程,计算机将数据与代码分别存储在数据段(DS)和代码段(CS)中,CPU按照EIP寄存器中存储的指令地址,逐条获取并执行CS中的指令,并将中间结果保存在DS中。
--------------------------------------------------------------------------------------------------
by 陈秋阳
原创作品转载请注明出处
《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000