内存管理之栈(stack)和堆(heap)

栈是内存中给一个线程预留的内存空间,有编译器自动管理分配和释放。栈遵循LIFO(Last in First out)的顺序,通过指针可以方便的释放空间。

堆是动态分配的空间,一般情况下由一个程序的多个线程共用。比如C++中用new创建的对象存放于堆中。

堆和栈中的存储内容

栈中存放函数调用的参数和局部变量等。顺序是在函数调用时,函数调用语句的下一条可执行语句的地址首先进栈,接着是函数的各个参数,一般是由右往左的顺序进行入栈操作,再然后是函数中的局部变量。 当本次函数调用结束后,以与入栈相反的顺序进行出栈操作,局部变量先出栈,接着是参数,最后栈顶指针指向最开始存的地址,也就是主函数中的下一条指令,程序以该点位置继续往后运行。 另外对象也可以存放在栈中。

堆一般是在堆的头部用一个字节存放堆的大小。堆中的具体内容则有程序员安排。例如通过new声明的对象存放在堆中。

栈和堆大小的区别?

栈的大小是固定的。当程序申请的内存大小大于栈可分配的内存时,会出现stack overflow. 堆的大小不是固定的,当程序运行时大小可以根据需求变化。

栈和堆的访问速度和机制?

栈的读写速度更快,因为分配内存的机制,只是移动指针,而堆还要做查找等操作。见下图。

 

栈的读取机制类似于数据机构栈,而堆类似于数据结构链表。

全局变量和静态变量存放在哪里?

全局变量和静态变量既不存放在栈上也不存放在堆上 ,而是存放在内存中的静态区域(static)。

参考链接

https://blog.csdn.net/seanchen88/article/details/53388755

https://blog.csdn.net/waidazhengzhao/article/details/76651923

猜你喜欢

转载自www.cnblogs.com/zhetong/p/10226454.html