Poedu_计算机科学导论_Lesson06_6_2018-9-23

  • 汇编约等于机器码
  • 我们的代码通过编译器翻译成与之一一对应的汇编码
  • 我们为了更好的组织我们所生成程序的空间,我们会整体的将内存划分为几块,这样我们的程序会更加的安全
  • 栈区开始时默认是1024KB大小,栈会存储一些临时变量,栈区是可增长的
  • 栈不仅仅是存储临时变量的地方,栈还会存储一些其他的东西,例如:跳转后返回地址
  • 堆是分配出一块空间,它和栈不同的地方在于它与栈的排列不同,当程序员使用时,当你使用时就可以使用,但使用完后必须自己手动释放,如果不释放会出现内存泄漏的问题

源代码到可执行文件的过程

 栈的逻辑工作原理

        栈的使用效率高是因为它可以反复来使用。

        栈在最底层定一个游标,用ebp寄存器记录这个游标,每次使用临时变量占用一块内存空间,再拿另一个游标esp指向最高点,当使用完成之后,就将esp与ebp两者相重合,相当于之前的临时变量作废。

 跳转后返回地址

   程序是按顺序执行,它首先会先把参数进行压栈,在call之后会把返回地址进行一个记录,此后会进行EBP的保存,接着将ESP的值给EBP,EBP的值发生改变,与ESP相同。接下来会进行sub分配空间等操作,在结尾时进行add操作,cmp判断操作,将EBP值给ESP,接着EBP出栈,返回地址

  • push:压栈
  • pop  :出栈
  • ebp  :栈底
  • esp  :栈顶
  • mov :移动

猜你喜欢

转载自blog.csdn.net/Black_Melody/article/details/82824939