Chinaunix首页 | 论坛 | 博客
  • 博客访问: 21020
  • 博文数量: 7
  • 博客积分: 16
  • 博客等级: 民兵
  • 技术积分: 45
  • 用 户 组: 普通用户
  • 注册时间: 2011-11-02 20:44
文章分类
文章存档

2012年(3)

2011年(4)

分类:

2011-11-16 20:06:02

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

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

上一篇:没有了

下一篇:“电脑病”完全实用手册

给主人留下些什么吧!~~