- 汇编约等于机器码
- 我们的代码通过编译器翻译成与之一一对应的汇编码
- 我们为了更好的组织我们所生成程序的空间,我们会整体的将内存划分为几块,这样我们的程序会更加的安全
- 栈区开始时默认是1024KB大小,栈会存储一些临时变量,栈区是可增长的
- 栈不仅仅是存储临时变量的地方,栈还会存储一些其他的东西,例如:跳转后返回地址
- 堆是分配出一块空间,它和栈不同的地方在于它与栈的排列不同,当程序员使用时,当你使用时就可以使用,但使用完后必须自己手动释放,如果不释放会出现内存泄漏的问题
源代码到可执行文件的过程
栈的逻辑工作原理
栈的使用效率高是因为它可以反复来使用。
栈在最底层定一个游标,用ebp寄存器记录这个游标,每次使用临时变量占用一块内存空间,再拿另一个游标esp指向最高点,当使用完成之后,就将esp与ebp两者相重合,相当于之前的临时变量作废。
跳转后返回地址
程序是按顺序执行,它首先会先把参数进行压栈,在call之后会把返回地址进行一个记录,此后会进行EBP的保存,接着将ESP的值给EBP,EBP的值发生改变,与ESP相同。接下来会进行sub分配空间等操作,在结尾时进行add操作,cmp判断操作,将EBP值给ESP,接着EBP出栈,返回地址
- push:压栈
- pop :出栈
- ebp :栈底
- esp :栈顶
- mov :移动