栈内存是如何被编译器维护的
我们一直听说“栈内存由编译器维护”,那是如何维护的呢?是在程序运行期间由编译器来管理栈内存吗?怎么可能!
以函数调用时的出入栈为例:原来编译器在编译函数调用代码时,不仅编译成call指令,还会在call指令之前添加若干入栈指令:push,在函数返回时会添加对应的出栈指令:pop。这部分是程序员无法控制的,因此叫作栈内存由编译器维护,并非运行期间维护的,而是编译期间就提前决策千里之外了^-^
栈:在函数调用时,第一个进栈的是主函数中后的下一条指令(函数调用语句的下一条可执行语句)的地址,然后是函数的各个参数,在大多数的C编译器中,参数是由右往左入栈的,然后是函数中的局部变量。注意静态变量是不入栈的。当本次函数调用结束后,局部变量先出栈,然后是参数,最后栈顶指针指向最开始存的地址,也就是主函数中的下一条指令,程序由该点继续运行。
关于进程空间的概念请阅读:Linux进程空间与虚拟地址的好处
我们一直听说“栈内存由编译器维护”,那是如何维护的呢?是在程序运行期间由编译器来管理栈内存吗?怎么可能!
以函数调用时的出入栈为例:原来编译器在编译函数调用代码时,不仅编译成call指令,还会在call指令之前添加若干入栈指令:push,在函数返回时会添加对应的出栈指令:pop。这部分是程序员无法控制的,因此叫作栈内存由编译器维护,并非运行期间维护的,而是编译期间就提前决策千里之外了^-^
栈:在函数调用时,第一个进栈的是主函数中后的下一条指令(函数调用语句的下一条可执行语句)的地址,然后是函数的各个参数,在大多数的C编译器中,参数是由右往左入栈的,然后是函数中的局部变量。注意静态变量是不入栈的。当本次函数调用结束后,局部变量先出栈,然后是参数,最后栈顶指针指向最开始存的地址,也就是主函数中的下一条指令,程序由该点继续运行。
关于进程空间的概念请阅读:Linux进程空间与虚拟地址的好处