堆和栈基本知识

一、定义

堆栈是不同的两种数据结构,堆:队列优先,先进先出。栈,先进后出。

堆栈空间分配

栈(操作系统):由操作系统自动分配释放,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。

堆(操作系统):一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。

堆栈缓存方式

栈使用的是一级缓存,他们通常都是被调用时处于存储空间中,调用完毕立即释放。

堆则是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定(并不是一旦成为孤儿对象就能被回收)。所以调用这些对象的速度要相对来得低一些。

堆栈数据结构区别

堆(数据结构):堆可以被看成是一棵树,如:堆排序。

栈(数据结构):一种先进后出的数据结构。

二、程序的内存分配

c的程序内存分为以下几个部分。

举个例子来说明程序的内存分配

以前大神写的例子,借鉴。

int   a

=   0;全局初始化区

char

*p1;全局未初始化区

main()

{

int

b;栈

char

s[]   =   "abc";栈

char

*p2;栈

char

*p3   =   "123456";   123456/0在常量区,p3在栈上。

static

int   c   =0;全局(静态)初始化区

p1  =   (char   *)malloc(10);

p2  =   (char   *)malloc(20);

分配得来得10和20字节的区域就在堆区。

strcpy(p1,

"123456");   123456/0放在常量区,编译器可能会将它与p3所指向的"123456"

优化成一个地方。

}

三、比较

栈:栈是由操作系统进行分配管理,存储在内存中的一级缓存中,所以存储速度优于堆在二级缓存的结构。读取速度快。

堆:程序员自己进行控制,有什么需求,就可以向内存进行申请,但是容易产生碎片。

举个例子:我们去家具店买家具,都是现成的,有桌子,椅子,衣柜等。种类很多,如果你选择直接购买的话,就类似于栈,如果你只是去学习人家的形状和潮流的话,回来自己买工具,木头等自己制作。那么就像是堆。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在和计算机内存打交道时,我们一定会碰到堆和栈,这两个东西很容易搞混,那么现在就来梳理一下二者的关系。 栈(Stac...
    Albert陈凯阅读 6,895评论 0 6
  • “text segment ”是应用程序运行时应用程序代码存在的内存段。每一个指令,每一个单个函数、过程、方法和执...
    紫云夕月阅读 12,046评论 4 20
  • 在数据结构中堆和栈都是一种数据项按序排列的数据结构,但我们今天所说的重点并不是数据结构中的堆和栈,而是C语言内存分...
    Joe_HUST阅读 2,801评论 0 0
  • 没有想要每天道一声早安晚安的人觉得其实确实很孤独。单身的人总爱说一个人也还好,可是只是还好而已。 现在越来越感觉自...
    洛水尘门阅读 1,592评论 1 1
  • 清明前夕,单身狗彭总,蒋公一同好基友看了好莱坞科幻爱情故事《太空旅客》,有感而发洋洋洒洒千余字的人生感悟…一时引...
    鹏仔_a29c阅读 1,319评论 0 0