Chinaunix首页 | 论坛 | 博客
  • 博客访问: 312849
  • 博文数量: 172
  • 博客积分: 25
  • 博客等级: 民兵
  • 技术积分: 895
  • 用 户 组: 普通用户
  • 注册时间: 2011-11-09 16:57
文章分类

全部博文(172)

文章存档

2012年(86)

2011年(86)

分类:

2011-11-15 19:53:55

原文地址:堆与栈的区别 作者:zffjh2021

栈是由编译器在程序运行时分配空间区域,由操作系统维护。(局部变量,函数参数等)
堆是由malloc()函数分配的内存块,内存释放由程序员手动控制,在C中使用free,在C++中使用delete。
 
它们的主要区别有:
1.管理方式不同
程序在运行时栈由操作系统自动管理,无需程序员手动控制;而堆空间的申请释放工作由程序员控制,容易产生内存泄露。
2.空间大小不同
栈是向低地址扩展的数据结构,是一块连续的内存区域。
堆是向高地址扩展的数据结构,是一块不连续的内存区域,系统用链表来存储。
3.产生碎片不同
对于堆来讲,频繁的malloc/free势必会造成内存空间的不连续,从而造成大量的碎片。而栈没有。
4.增长方式不同
5.分配方式不同
6.分配效率不同
堆的分配效率比栈要低得多。
阅读(611) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~