找回密码
 注册
关于网站域名变更的通知
查看: 319|回复: 4
打印 上一主题 下一主题

数据栈的使用规则

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2016-6-4 14:56 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
根据堆栈指针指向位置的不同,堆栈可分为满栈和空栈2种。当堆栈指针指向栈顶元素,即指向最后一个入栈的数据元素时,称为满栈;当堆栈指针指向与栈顶元素相邻的一个可用数据单元时,称为空栈。
/ R  s; X4 v5 c7 l0 \8 E; ^根据数据栈增长方向的不同也可分为递增堆栈和递减堆栈2种。当数据着呢向内存地址减小的方向增长时,称为递减堆栈;当数据栈向内存地址增加的方向增长时,称为递增堆栈。
# P! _  r8 |. _8 n综合这2种特点则可有以下4种数据栈:
& C2 L# l; U& OFD          满堆栈' X: r- _. ^+ U1 v+ f: B
ED         空递减+ b5 f! \5 j2 t! M; e
FA          满递增6 p/ p! X8 z* f8 U
EA         空递增# F8 a; W4 M* {, J8 N1 w6 a3 O
ATPCS规定数据栈为FD类型,并且要对数据栈的操作是8字节对齐的。异常中断的处理程序可使用中断程序的数据栈,但要保证中断程序的数据栈足够大。以下是与数据栈相关的名词。! o$ w! [4 n/ C8 E9 E5 T/ O
数据栈指针:最后一个写入栈的数据的内存地址。$ q% ?2 K3 Q: y1 ~/ c  t: Y! A
数据栈的基地址:数据栈的最高地址。由于ATPSC中的数据栈是FD型的,多以最早入栈的数据所占的内存单元时基地址的下一个内存单元。
& x9 ^( ~1 X& \7 C* M) g- b3 Z) K9 V数据栈界限:数据栈中可使用的最低的内存单元地址。
+ y/ `3 v9 D! w! L已用的数据栈:数据栈的基地址和数据栈的栈指针之间内存区域,包括栈指针对应的内存单元,但不包括基地址对应的内存单元。
: q2 i* G) a! x+ |/ }未用的数据栈:数据栈是真和数据栈界限之间的内训区域,包括数据栈界限对应的内存单元,但不包括栈指针对应的内存单元。
8 E( \! ?' f; J- z" g数据栈中的数据帧:数据栈中为子程序分配的用来保存寄存器和局部变量的区域。

该用户从未签到

2#
发表于 2016-6-4 15:05 | 只看该作者
学习中,谢谢分享

该用户从未签到

3#
发表于 2016-9-2 14:43 | 只看该作者
) U" r1 F8 U' z, u. |* l
学习中,谢谢分享

该用户从未签到

4#
发表于 2016-9-3 14:10 | 只看该作者
学习中,谢谢分享) \4 t4 J4 v# U! U* o9 Z
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-8-2 14:29 , Processed in 0.109375 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表