关于堆栈的简单认识

堆栈的含义

堆栈是一个特定的存储区或寄存器,它的一端是固定的,另一端是浮动的 [1] 。对这个存储区存入的数据,是一种特殊的数据结构。所有的数据存入或取出,只能在浮动的一端(称栈顶)进行,严格按照**“先进后出”**的原则存取,位于其中间的元素,必须在其栈上部(后进栈者)诸元素逐个移出后才能取出。在内存储器(随机存储器)中开辟一个区域作为堆栈,叫软件堆栈;用寄存器构成的堆栈,叫硬件堆栈。
单片机应用中,堆栈是个特殊存储区,堆栈属于RAM空间的一部分,堆栈用于函数调用、中断切换时保存和恢复现场数据。堆栈中的物体具有一个特性:第一个放入堆栈中的物体总是被最后拿出来, 这个特性通常称为先进后出 (FILO—First-In/Last-Out)。 堆栈中定义了一些操作, 两个最重要的是PUSH和POP。 PUSH(入栈)操作:堆栈指针(SP)加1,然后在堆栈的顶部加入一 个元素。POP(出栈)操作相反,出栈则先将SP所指示的内部ram单元中内容送入直接地址寻址的单元中(目的位置),然后再将堆栈指针(SP)减1。这两种操作实现了数据项的插入和删除。

堆和栈的理论知识

1.申请方式
栈:由系统自动分配。例如,声明在函数中的一个局部变量int b,系统自动在栈中为b
开辟空间。
堆:需要程序员自己申请,并指明大小,在C中用malloc函数。
如:
在C++中用new运算符,如:
但是注意p1、p2本身是在栈中的。
2.申请后系统的响应
栈:只要栈的剩余空间大于所申请空间,系统将为程序提供内存,否则将报异常提示栈
溢出。
堆:首先应该知道操作系统有一个记录空闲内存地址的链表,当系统收到程序的申请
时,会遍历该链表,寻找第一个空间大于所申请空间的堆节点,然后将该节点从空闲节点链
表中删除,并将该节点的空间分配给程序。对于大多数系统,会在这块内存空间中的首地址
处记录本次分配的大小,这样,代码中的delete语句才能正确地释放本内存空间。另外,由
于找到的堆节点的大小不一定正好等于申请的大小,系统会自动地将多余的那部分重新放入
空闲链表中。
3.申请大小的限制
栈:在Windows下,栈是向低地址扩展的数据结构,是一块连续的内存的区域。这句话
的意思是栈顶的地址和栈的最大容量是系统预先规定好的,在Windows下,栈的大小是
2MB(也有的说是1MB,总之是一个编译时就确定的常数),如果申请的空间超过栈的剩余
空间,将提示overflow。因此,能从栈获得的空间较小。
堆:堆是向高地址扩展的数据结构,是不连续的内存区域。这是由于系统是用链表存储
空闲内存地址的,自然是不连续的。而链表的遍历方向是由低地址向高地址,堆的大小受限
于计算机系统中有效的虚拟内存。由此可见,堆获得的空间比较灵活,也比较大。
.略略略。

堆栈的应用

堆栈主要的特点:是限制数据插入、删除的位置。属于有序链表的应用。

应用:二叉树及森林的遍历运算。中序遍历inorder、前序遍历preorder。

CPU的中断处理(Interupt Handling)

图的深度优先(DFS)遍历法。

Stack computer

递归程序的调用及返回。

算术表达式的转换和求和。

调用子程序及返回处理。

编译错误处理。

例子:使用LinkedList完成一个堆栈(表示一个先进后出的数据结构)

在这里插入图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值