内存管理之栈(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

转载于:https://www.cnblogs.com/zhetong/p/10226454.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值