Chinaunix首页 | 论坛 | 博客
  • 博客访问: 287838
  • 博文数量: 182
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1292
  • 用 户 组: 普通用户
  • 注册时间: 2015-05-06 19:02
个人简介

让一切的准备都完美演出,让所有的努力都美好落幕

文章分类

全部博文(182)

文章存档

2016年(60)

2015年(122)

我的朋友

分类: C/C++

2015-07-08 20:55:16

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

上一篇:SDP学习

下一篇:负载均衡

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