堆和栈

栈区(stack)由编译器自动分配释放 ,存放方法(函数)的参数值, 局部变量的值等,栈是向低地址扩展的数据结构,是一块连续的内存的区域。即栈顶的地址和栈的最大容量是系统预先规定好的。栈是先进后出的队列。
堆区(heap)一般由程序员分配释放, 若程序员不释放,程序结束时由OS回收,向高地址扩展的数据结构,是不连续的内存区域,从而堆获得的空间比较灵活。频繁的new/delete势必会造成内存空间的不连续,从而造成大量的碎片,使程序效率降低。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原文:http://stackoverflow.com/questions/79923/what-and-wher...
    toplee阅读 923评论 0 1
  • 摘自http://blog.jobbole.com/75321/ 问题描述 编程语言书籍中经常解释值类型被创建在栈...
    许小小晴阅读 573评论 0 0
  • 问题描述 编程语言书籍中经常解释值类型被创建在栈上,引用类型被创建在堆上,但是并没有本质上解释这堆和栈是什么。我仅...
    波波维奇popovich阅读 306评论 1 3
  • 深度优先搜索,小蜜蜂采蜜最短路径 LeetCode经典题 1. 贪心算法 455 分发糖果376 摇摆序列402 ...
    渡猫阅读 468评论 0 0
  • 希望现在的你,别害怕现状,也别试图强迫自己 世事无常,总要有一段日子是用来浪费的,总会有无能为力的不愉快,让...
    听风归子墨染阅读 586评论 0 4