堆栈的区别
2016-04-28 21:54
253 查看
要了解堆和栈的区别,我们首先要了解系统的分区
BSS(Block Started by Symbol)通常是指用来存放程序中未初始化的全局变量和静态变量的一块内存区域.
数据段(data segment)通常是指用来存放程序中已初始化的全局变量的一块内存区域.
代码段(code segment / text segment)通常是指用来存放程序执行代码的一块内存区域
栈区(stack)— 由编译器自动分配释放,存放函数的参数值,局部变量的值等。其
操作方式类似于数据结构中的栈。
堆区(heap)一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表代码的一块内存区域。
再次,必须明白一点也是非常重要的的一点,栈是向下生长,所谓的向下生长是指从高地址->低地址的路径延伸。从而栈有栈底和栈顶,那么栈顶的地址比栈底低。然后堆是向上生长的。
最后引用一句高手的的来做总结:
堆和栈的区别可以用如下的比喻来看出:
使用栈就象我们去饭馆里吃饭,只管点菜(发出申请)、付钱、和吃(使用),吃饱了就
走,不必理会切菜、洗菜等准备工作和洗碗、刷锅等扫尾工作,他的好处是快捷,但是自
由度小。
使用堆就象是自己动手做喜欢吃的菜肴,比较麻烦,但是比较符合自己的口味,而且自由
度大。 (经典!)
BSS(Block Started by Symbol)通常是指用来存放程序中未初始化的全局变量和静态变量的一块内存区域.
数据段(data segment)通常是指用来存放程序中已初始化的全局变量的一块内存区域.
代码段(code segment / text segment)通常是指用来存放程序执行代码的一块内存区域
栈区(stack)— 由编译器自动分配释放,存放函数的参数值,局部变量的值等。其
操作方式类似于数据结构中的栈。
堆区(heap)一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表代码的一块内存区域。
再次,必须明白一点也是非常重要的的一点,栈是向下生长,所谓的向下生长是指从高地址->低地址的路径延伸。从而栈有栈底和栈顶,那么栈顶的地址比栈底低。然后堆是向上生长的。
最后引用一句高手的的来做总结:
堆和栈的区别可以用如下的比喻来看出:
使用栈就象我们去饭馆里吃饭,只管点菜(发出申请)、付钱、和吃(使用),吃饱了就
走,不必理会切菜、洗菜等准备工作和洗碗、刷锅等扫尾工作,他的好处是快捷,但是自
由度小。
使用堆就象是自己动手做喜欢吃的菜肴,比较麻烦,但是比较符合自己的口味,而且自由
度大。 (经典!)
相关文章推荐
- 如何利用“IP地址欺骗”
- 网络管理之IP地址篇
- ip地址基础知识
- IP地址组成与类型
- Ruby中require、load、include、extend的区别介绍
- Ruby中的p和puts的使用区别浅析
- Ruby中的block、proc、lambda区别总结
- Redis和Memcached的区别详解
- Lua中调用函数使用点号和冒号的区别
- Lua中关于求模与求余的区别介绍
- TMP、TEMP和TMP文件区别解析
- C#基础语法:结构和类区别详解
- 深入c# 类和结构的区别总结详解
- C#中string.Empty和null的区别详解
- sqlserver和oracle中对datetime进行条件查询的一点区别小结
- 网页中Span和Div的区别
- 大家看了就明白了css样式中类class与标识id选择符的区别小结
- C#中类与结构的区别实例分析
- SQL 中having 和where的区别分析
- c#中(int)、int.Parse()、int.TryParse、Convert.ToInt32的区别详解