本文是汇编语言的开始
在其他高级语言里,一开始上来就是打印hello world;我认为汇编的第一个可运行的代码不是hello world,是mov ax, 1
。
函数序言
esp栈顶,ebp栈底位置;
入栈
add esp, 4
出栈
sub esp, 4
这是在32位机器上运行的,一次性能够压入4个字节的数据入栈(4个字节也就是32位,同理如果是64位机器,可以入栈8个字节数据)
理解入栈esp的值变化
理解入栈,时候为什么是栈顶往是加,而不是减少。是因为在机器初期,硬件资源非常稀缺;在起始地址开始位置分配给程序段相关。
比如运行一个程序段,然后地址向前加若干字节;此时需要记录一下别的事情,比如记录一块数据,一个函数,等会再用。这时要记录在别处,为了方便可以从地址的后面往前记录。
就像做笔记一样,你只有一个笔记本,前面都是记录一下顺序事情,突然你想涂涂画画,为了不打乱前面的记录,从笔记本的后面往前记录是一个很好的方法。汇编语言中的堆栈记录数据也是这种方式。
理解堆栈名词
注意:编程语言中经常说到堆栈,其实就是栈,不是数据结构中的堆和栈。堆栈中的堆时一个动词,数据存放的意思,我理解成 “堆货”,“堆数据”。 再比如Java中的堆栈也是栈,而Java中也有堆的说法,堆也是跟栈一样,存放的数据的地方。堆的数据结构跟栈不同,堆的数据结构是一棵树;类似mysql数据库中的索引,你要把它理解成堆也没问题;只是通常中的堆一般存放在缓存(RAM)中的树。
表示函数启动运行前执行的一系列
push ebp
mov ebp, esp
sub esp, 0c0h ;为局部变量申请存储空间
函数尾声
mov esp, ebp
pop ebp
ret