堆栈指针SP的问题,很奇怪,大家进来看一下,谢谢
org 0000h
ajmp main
org 0050h
main:mov sp,#32h
mov 30h,#50h
mov 31h,#5Fh
mov 32h,#3ch
POP DPH;
POP DPL;
POP SP;
nop
end
运行完以上程序后,我不理解为什么sp=50h,执行POP SP首先把(30H)=50H的内容给SP,然后因为是出栈所以要减一不是吗?为什么不是(SP)=4FH ?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
操作【1】:pop SP 产生 sp-1 的操作是由硬件直接改写,没有通过地址总线和数据总线,
操作【2】:而【((SP))→direct】中的赋值操作必须通过内部地址总线和数据总线读取【((SP))】改写【→direct】寄存器,
这一操作【2】相对于前一操作【1】要慢上若干时钟周期,
所以即使 sp-1操作在后,也会提前完成。
一周热门 更多>