您的位置:

c语言中如何定义堆,c语言堆的定义

本文目录一览:

c语言中 堆怎么理解?

c中代码在代码段,数据在数琚段,局部变量在堆栈中,除了这些已经明确安排好的空间,剩余空间称为自由空间,要利用这些空间可以通过内存分配函数,动态分配,这部分空间称为堆空间!堆空间相比栈空间是非常大的,栈空间是非常有限的windows下32位程序,缺省约为1M而每个程序的地址空间为4G,堆空间使用1~2G内存是不成问题的。

至于p那个指针本身是局部变量,p所指内存在堆上出了函数也是可以用的,必须能够传递出去才行,p自己只能在函数内部使用!传递出去的指针必须在适当的时候释放,否则会产生内存泄漏!

1)这么理解似平不是问题,不过太肤浅;

2)由于各种编程语言(包括c,c )不能(也不允许)直接访问内存,和cpu各寄存器,要通过标志符(就是一个名字)来访问它们,这就牵扯到名字的作用域问题了!而内存,寄存器这些东西本来就在和语言无关,只和该语言如何使用有关,通过名字,我们可以更清晰的理解代码的意图,可以更好的安排代码,所以各种语言,通过名字来使用内存和寄存器!这样名字就和内存,寄存器这种实际存在的东西联系到一起了!变量是最经常使用的一种名字了!对c,这种语言自动变量在堆上,只有函数内部甚至内部的一对大括号内可用(即变量名可见,如果变量的相关内容,如变量值,变量地址,传递出去,外部也是可以使用的,当然同一程序的内部变量地址就不要传递了!同样参数和返回值也不要把自动变量地址传递出去,因为已经过期,有可能被别的东西占用了,使用会么错的,而动态分配的内存其实属于全局性质的,传递出去是没问题的,只要能够及时释放就行,那就是无名全局数据,可以通过有名变量(指针)来使用,因为没有名字所以不能直接促使用,因为是全局的所以可以任意传递,因为要管理的,所以用完要释放!因为无名,所以只能间接引用!

C程序中如何使用堆栈

先从大家比较熟悉的栈说起,它是一种具有后进先出性质的数据结构,也就是说后存放的先取,先存放的后取。这就如同要取出放在箱子里面底下的东西(放入的比较早的物体),首先要移开压在它上面的物体(放入的比较晚的物体)。而堆就不同了,堆是一种经过排序的树形数据结构,每个结点都有一个值。通常所说的堆的数据结构,是指二叉堆。堆的特点是根结点的值最小(或最大),且根结点的两个子树也是一个堆。由于堆的这个特性,常用来实现优先队列,堆的存取是随意,这就如同在图书馆的书架上取书,虽然书的摆放是有顺序的,但是想取任意一本时不必像栈一样,先取出前面所有的书,书架这种机制不同于箱子,可以直接取出想要的书。

下面就说说C语言程序内存分配中的堆和栈,这里有必要把内存分配也提一下,一般情况下程序存放在Rom或Flash中,运行时需要拷到内存中执行,内存会分别存储不同的信息。

内存中的栈区处于相对较高的地址以地址的增长方向为上的话,栈地址是向下增长的,栈中分配局部变量空间,堆区是向上增长的用于分配程序员申请的内存空间。另外还有静态区是分配静态变量,全局变量空间的;只读区是分配常量和程序代码空间的;以及其他一些分区。来看一个网上很流行的经典例子:

main.cpp

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);

}

堆和栈的第一个区别就是申请方式不同:栈(英文名称是stack)是系统自动分配空间的,例如定义一个

char

a;系统会自动在栈上为其开辟空间。而堆(英文名称是heap)则是程序员根据需要自己申请的空间,例如malloc(10);开辟十个字节的空间。由于栈上的空间是自动分配自动回收的,所以栈上的数据的生存周期只是在函数的运行过程中,运行后就释放掉,不可以再访问。而堆上的数据只要程序员不释放空间,就一直可以访问到,不过缺点是一旦忘记释放会造成内存泄露。

C语言中"栈"和"堆"怎么理解?

堆(heap)和栈(stack)有什么区别??

简单的可以理解为:

heap:是由malloc之类函数分配的空间所在地。地址是由低向高增长的。

stack:是自动分配变量,以及函数调用的时候所使用的一些空间。地址是由高向低减少的。

一个由c/C++编译的程序占用的内存分为以下几个部分

1、栈区(stack)—

由编译器自动分配释放

,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。

2、堆区(heap)

一般由程序员分配释放,

若程序员不释放,程序结束时可能由OS回收

。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表。

C语言中的堆和栈的定义?

在数据结构上要知道堆栈,尽管我们这么称呼它,但实际上堆栈是两种数据结构:堆和栈。

堆和栈都是一种数据项按序排列的数据结构。

栈就像装数据的桶或箱子

我们先从大家比较熟悉的栈说起吧,它是一种具有后进先出性质的数据结构,也就是说后存放的先取,先存放的后取。

这就如同我们要取出放在箱子里面底下的东西(放入的比较早的物体),我们首先要移开压在它上面的物体(放入的比较晚的物体)。

堆像一棵倒过来的树

而堆就不同了,堆是一种经过排序的树形数据结构,每个结点都有一个值。

通常我们所说的堆的数据结构,是指二叉堆。

堆的特点是根结点的值最小(或最大),且根结点的两个子树也是一个堆。

由于堆的这个特性,常用来实现优先队列,堆的存取是随意,这就如同我们在图书馆的书架上取书,虽然书的摆放是有顺序的,但是我们想取任意一本时不必像栈一样,先取出前面所有的书,书架这种机制不同于箱子,我们可以直接取出我们想要的书。