在64位的linux终端下通过执行命令gcc –S –o main.s main.c -m32得到对应的汇编代码文件

 


去掉main.s中以.开头的链接符号得到如下所示的汇编代码:

 

 

通过上面的汇编代码我们知道堆栈是向下增长的,函数调用对应的汇编指令为call f。

 

以下是几条重要的汇编指令,我用课程截图的方式记录了下来:

 

各寄存器解释:

ebp:堆栈栈底寄存器

esp:堆栈栈顶寄存器

eip:自动跳转下一行运行程序

下面是堆栈变化情况,注意:上面是地地址,堆栈向下增长。

下面是在听课时做的笔记:

 

 

总结:

计算机工作原理就是:计算机在堆栈和各类寄存器的帮助下,对数据进行各种操作,从而形成计算结果。

进一步而言就是,具体的寄存器:eax通用寄存器,eip程序计数器,esp:栈顶指针,ebp:栈底指针。在这些寄存器的帮助下,数据和各类跳转信息,在程序栈之中上上下下的移动,从而形成跳转和eax数据累加等操作,把复杂的程序进行拆分成大量的栈操作,从而形成计算结果。

 

相关文章:

  • 2021-06-01
  • 2022-03-01
  • 2021-12-06
  • 2021-05-01
  • 2022-03-09
  • 2021-07-27
  • 2021-08-03
猜你喜欢
  • 2021-12-27
  • 2021-08-11
相关资源
相似解决方案