A. 8051单片机堆栈
51单片机的堆栈是向上生长的,就是堆栈不为空时,栈底地址小于栈顶地址,当将数据入栈时,栈顶地址增加。还有一个技巧是,堆栈是数据存储器的一部分,也就是说堆栈除了利用push和pop访问,也可以通过普通的选址方法访问,例如mov。有时我们想访问堆栈数据,但不想改动变动栈顶,这时可以通过mov来访问数据。还有一个书上很少提到的知识点是出栈之后,原来那个栈顶的内容并不会清零,所以我们依然可以像对待普通数据存储器一样访问。
B. 单片机堆栈问题
堆栈的压栈动作地址是递减的;出栈动作地址是增加的。sp是栈顶指针,经过压栈动作后的值要比70H小。具体的数值得看单片机的位数——32 bit/16 bit/8 bit
C. 单片机的堆栈是怎样工作的
单片机中的堆栈是1个连续的存储区,采取后入先出的方式存取数据。1般PUSH操作是向堆栈中存入数据,POP操作从堆栈取得数据。PUSH的操作顺序和POP的操作顺序正好相反,例如有A.B.C.D4个变量的值,依照PUSH
A,PUSH
B,PUSH
C和PUSH
D存入堆栈,则需要用POP
D,
POP
C,
POP
B,POP
A的顺序提取。如果ABCD的类型字长1致,则堆栈还可用来交换变量的值,例如PUSH
A,PUSH
B,然后用POP
A,
POP
B来实现A和B两个变量值的互换。但这样的操作不是所有单片机都支持。
D. 简述51单片机堆栈进栈和出栈操作规则
1.堆栈用于响应中断或调用子程序时保护断点地址,也可通过栈操作指令(push
和pop保护和恢复现场)其中入栈时先SP+1再将内容压入当前SP所指示的堆栈单元
中,出栈则先将SP所指示的内部ram单元中内容送入直接地址寻址的单元中,再将
SP减1.
2.中断允许寄存器的功能是控制CPU对中断的开放和屏蔽以及每个中断源是否允许
中断结构包括EA(CPU中断总允许位),ES(串行口中断允许位)ET1(定时器1中
断允许位)EX1(外部中断1中断允许位)ET0(定时器0中断允许位)EX0(外部中
断0中断允许位)
3.T机=12/fosc=12/(6*E6)=2us
X=2*E13-T/T机=8192-200/2=8092=1F9CH=1111 1100 1110 0B
因为TL1的高3位未用, 修正后X=1111 1100 0001 1100B=FC1CH
4.LJMP为长转移指令,可转向64KB程序存储器的任一单元;SJMP为相对转移指令
,偏移范围-128~+127共259字节;AJMP为绝对转移指令,转移目的在指令后一个
E. 单片机堆栈是怎么运算
51单片机堆栈是在片内RAM区实现的能先进后出的一个存储区域,由SP寄存器实现数据的入栈和出栈,当有数据入栈时,比如PUSH
ACC,此时SP先加一,然后把ACC中的内容存到SP所指向的内存单元中。出栈时,比如POP
ACC,此时先把SP所指向的内存单元(栈顶单元)内容送到ACC中,然后SP减一
F. 8051单片机堆栈设置在什么地方,如何实现
8051单片机在复位后,堆栈的底部就在07H,压栈时,将向08H方向增长。
如果需要改变默认值,可以在初始化阶段使用如下指令:
MOV SP, #6FH即可将堆栈的底部设置在6FH。

(6)堆栈过程单片机扩展阅读:
基本结构:
51 单片机最初是由Intel 公司开发设计的,但后来Intel 公司把51 核的设计方案卖给了几家大的电子设计生产商,譬如 SST、Philip、Atmel 等大公司。
如是市面上出现了各式各样的但均以51 为内核的单片机,倒是Intel 公司自己的单片机却显得逊色了。这些各大电子生产商推出的单片机都兼容51 指令、并在51 的基础上扩展一些功能而内部结构是与51 一致的。
一个完整的计算机应该由运算器、控制器、存储器(ROM 及RAM)、数据总线和I/O 接口组成。一般微处理器(如8086)就只包括运算器和控制器两部分。
和一般微处理器相比,8051 增加了四个8 位I/O 口、一个串行口、4KB ROM、128BRAM、很多工作寄存器及特殊功能寄存器(SFR),所以单片机具有比微处理器更强大的控制功能,单片机是专为进行控制设计的,而常见的微处理器是用于运算功能的。