|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
根据堆栈指针指向位置的不同,堆栈可分为满栈和空栈2种。当堆栈指针指向栈顶元素,即指向最后一个入栈的数据元素时,称为满栈;当堆栈指针指向与栈顶元素相邻的一个可用数据单元时,称为空栈。
- A! [4 S6 U% T/ F根据数据栈增长方向的不同也可分为递增堆栈和递减堆栈2种。当数据着呢向内存地址减小的方向增长时,称为递减堆栈;当数据栈向内存地址增加的方向增长时,称为递增堆栈。
* t) j: h" d. a: h8 g! w综合这2种特点则可有以下4种数据栈:! N1 L# [1 J$ [& |' q# \1 f! P
FD 满堆栈2 X8 c5 b4 ?% K* }( M! k! r: r- d
ED 空递减
+ \7 ]( }2 W( f* |FA 满递增
0 ^2 z$ y4 o4 y' g- B# b$ oEA 空递增% h* m: G% k: ~, q
ATPCS规定数据栈为FD类型,并且要对数据栈的操作是8字节对齐的。异常中断的处理程序可使用中断程序的数据栈,但要保证中断程序的数据栈足够大。以下是与数据栈相关的名词。. ~. f4 L8 M: o, ?1 T
数据栈指针:最后一个写入栈的数据的内存地址。
2 e5 Y& _/ M. o. b7 f" O2 S3 Y数据栈的基地址:数据栈的最高地址。由于ATPSC中的数据栈是FD型的,多以最早入栈的数据所占的内存单元时基地址的下一个内存单元。8 [* ]9 R5 { J( C
数据栈界限:数据栈中可使用的最低的内存单元地址。
, m7 J5 r- | v$ c9 m已用的数据栈:数据栈的基地址和数据栈的栈指针之间内存区域,包括栈指针对应的内存单元,但不包括基地址对应的内存单元。7 M& ^9 y# ~" ^' W
未用的数据栈:数据栈是真和数据栈界限之间的内训区域,包括数据栈界限对应的内存单元,但不包括栈指针对应的内存单元。; a7 k* g; }6 U, `4 w9 o! I1 t; }
数据栈中的数据帧:数据栈中为子程序分配的用来保存寄存器和局部变量的区域。 |
|