栈、堆的特点 区别

内存五大区域

栈(stack)

堆(heap)

静态区(全局区)又分为bss段(未初始化的全局变量、静态变量)

                                       data段(初始化的全局变量、静态变量)

常量区

代码区

 

1、栈(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。栈是向低址扩展的数据结构,是一块连续的内存的区域。是栈顶的地址和栈的最大容量是系统预先规定好的,栈的大小是2M

          由系统自动分配,速度较快,不会产生内存碎片。

2、堆(heap) — 一般由程序员分配(malloc\realloc\alloc)释放, 若程序员不释放,程序结束时可能由OS回收 。堆是由低向高地址扩展的类似链表数据结构,是不连续的内存区域。(这是由于系统使用链表来存储的空闲内存地址,而链表的遍历方向是由低地址向高地址)

         由alloc分配的内存,速度比较慢,而且容易产生内存碎片,不过使用起来最方便。

Published by

风君子

独自遨游何稽首 揭天掀地慰生平

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注