幼儿园园本课程的意义:堆栈到底是个怎么回事?

来源:百度文库 编辑:杭州交通信息网 时间:2024/04/29 06:07:12
很多书都提到堆栈,但是看了半天还是不怎么懂,谁能帮忙解释下啊~~~~:)

堆栈是一种执行“后进先出”算法的数据结构。

设想有一个直径不大、一端开口一端封闭的竹筒。有若干个写有编号的小球,小球的直径比竹筒的直径略小。现在把不同编号的小球放到竹筒里面,可以发现一种规律:先放进去的小球只能后拿出来,反之,后放进去的小球能够先拿出来。所以“先进后出”就是这种结构的特点。

堆栈就是这样一种数据结构。它是在内存中开辟一个存储区域,数据一个一个顺序地存入(也就是“压入——push”)这个区域之中。有一个地址指针总指向最后一个压入堆栈的数据所在的数据单元,存放这个地址指针的寄存器就叫做堆栈指示器。开始放入数据的单元叫做“栈底”。数据一个一个地存入,这个过程叫做“压栈”。在压栈的过程中,每有一个数据压入堆栈,就放在和前一个单元相连的后面一个单元中,堆栈指示器中的地址自动加1。读取这些数据时,按照堆栈指示器中的地址读取数据,堆栈指示器中的地址数自动减 1。这个过程叫做“弹出pop”。如此就实现了后进先出的原则。

堆栈是计算机中最常用的一种数据结构,比如函数的调用在计算机中是用堆栈实现的。
堆栈可以用数组存储,也可以用以后会介绍的链表存储。
下面是一个堆栈的结构体定义,包括一个栈顶指针,一个数据项数组。栈顶指针最开始指向-1,然后存入数据时,栈顶指针加1,取出数据后,栈顶指针减1。

#define MAX_SIZE 100
typedef int DATA_TYPE;
struct stack
{
DATA_TYPE data[MAX_SIZE];
int top;
};

堆和栈是两个不同的概念。

简单的来讲堆(heap)上分配的内存,系统不释放,而且是动态分配的。栈(stack)上分配的内存系统会自动释放,它是静态分配的。运行时栈叫堆栈。栈的分配是从内存的高地址向低地址分配的,而堆则相反。

由malloc或new分配的内存都是从heap上分配的内存,从heap上分配的内存必须有程序员自己释放,用free来释放,否则这块内存会一直被占用而得不到释放,就出现了“内存泄露(Memory Leak)”。这样会造成系统的可分配内存的越来越少,导致系统崩溃。

我没有从数据结构和微机原理的角度去说,因为一楼的已说清楚了。我是从操作系统的角度上来讲的。

题外:很多人认为在程序中尽量使用堆而不使用栈,因为堆栈溢出很危险。其实堆溢出比栈溢出更危险。哈哈~!

简单的说
堆栈
就是
把东西放到袋子里面
放满了后
要拿出来的话
就是从袋子的最上面拿起````

这就是先进去的后出来原则````

比如一个抽屉,你放和抽屉一样的大小的书进去,现在你要找一本书改怎么找呢(一样大小就是不能直接翻了),你要先把后面放进去的书拿出来才能拿到你后面的书.堆栈就是这样,后进先出,要取前面的数据先要把后压入栈的数据先取出来.

堆是一个概念(在排序时可能会用到),栈又是另外一个概念,通常所说的堆栈就是指的栈,栈的最基本的特点就是后进先出,就好比一个水桶一样,你只能从上面放入,也只能从上面取出,不可能水桶底下取东西,就这样~明白了吗?我可能说的不是很明白~