您的位置 首页 国产IC

C言语编程中的“堆”和“栈”七大不同之处

对于编程初学者来说会接触到一些难以理解的名称,比如堆(heap)、栈(stack)、堆栈(stack)等。初学开发过程中往往让人混淆不清。今天我们来谈谈堆和栈的具体区别,来帮助初学者理清思路。

  关于编程初学者来说会接触到一些难以了解的称号,比方堆(heap)、栈(stack)、仓库(stack)等。初学开发过程中往往让人混淆不清。今日咱们来谈谈堆和栈的详细差异,来协助初学者理清思路。

  堆和栈的差异一向都是永久的论题,为此我也查了许多的材料,以防自己的了解过错,而给他人形成了解误差。

  先从简略的一个比如引出堆和栈:

  void function(){

  int *p = (int *)malloc(10*sizeof(int));

  }

  这是C言语开发学习过程中,必不可免要学习的常识,动态分配一块空间,空间在堆区巨细是40字节(32位体系中)。而界说的指针变量p是局部变量(在栈区中
占用4字节空间),用来寄存刚刚前面动态分配的空间的首地址。能够看出,在这一句代码中一起包含了栈和堆,如图1所示。

  图1堆和栈

  咱们从以下几个方面比较一下堆和栈:

  (1)存储内容不同

  栈:在函数调用时,栈中寄存的是函数中(底下是函数调用后的下一条指令)各个参数(局部变量)。

  堆:一般是在堆的头部用一个字节寄存堆的巨细。堆中的详细内容有程序员组织。

  (2)管理方法上不同

  栈:由体系主动分配空间,一起体系主动开释空间。 例如,声明在函数中一个局部变量 int b;
体系主动在栈中为b拓荒空间,当对应的生计周期完毕后栈空间主动开释。

  堆:需求程序员手动请求并且手动开释,并指明巨细,在C言语中malloc函数请求,开释free函数,在C++中 new和delete完结。

  (3)空间巨细不同

  栈:获取空间较小。在Windows下,一般巨细是1M或2M,当剩下栈空间缺乏时,分配失利overflow。

  堆:取得空间依据体系的有用虚拟内存有关,比较灵敏,比较大。

  (4)能否发生碎片不同

  栈:不会发生碎片,空间接连。

  堆:选用的是链表的存储方法,会发生碎片。

  (5)成长方向不同

  栈: 向低地址扩展的数据结构,是一块接连的内存的区域。

  堆:
向高地址扩展的数据结构,是不接连的内存区域。这是因为体系是用链表来存储的闲暇内存地址的,自然是不接连的,而链表的遍历方向是由低地址向高地址。

  (6)分配方法不同

  栈:有2种分配方法:静态分配和动态分配,静态由编译器完结,例如局部变量;动态由alloca函数完结,并且编译器会进行开释。

  堆: 都是动态分配的,没有静态分配的堆。

  (7)分配功率不同

  栈:由体系主动分配,速度较快。但程序员是无法控制的。

  堆:由new分配的内存,一般速度比较慢,并且简单发生内存碎片,不过用起来便利。

  以上是栈和堆几个方面的不同,期望经过上面的材料能够协助初学者辨明堆和栈。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/bandaoti/ic/130112.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部