首先来了解一下,代码在内存中的分配,咱们先用图来看一下:
地址分配图很清楚的可以看出,代码在内从中分布。
其中要注意几点:
代码区具有只读性,文字常量也只具有只读性。
静态区又叫全局变量区,生命周期是文件的生命周期。
最主要的是栈和堆,栈的空间是系统管理,用时自动申请,不用时自动销毁。而堆是由程序员自己管理,自己申请自己销毁,如果不销毁就会产生内存泄漏。
接下来主要分析函数在栈中的调用,即函数的栈帧:
在了解函数栈帧之前,我们先得了解计算cpu中的几个寄存器。
1.EBP叫基址指针寄存器,用于指向栈底。
2.ESP叫指针寄存器也是EBP的一种,用于指向栈顶。
3.EIP/IP/PC叫指令寄存器,用来保存当前指令的下一条指令的地址。
还有很多寄存器,像EAX,EBX,ECX,EDX,DI 等,现在只需要知道这几个寄存器
我们还得知道:
代码的执行过程,在我们看来代码的入口就是main()函数,但是main()函数也是被其它函数调用,可以在VS2008中打开栈调用过程,可以看见调用main()函数的是mainC