鱼C论坛

 找回密码
 立即注册
查看: 2601|回复: 2

这个ax应该是3吧?为什么是6呢?

[复制链接]
发表于 2017-11-12 22:59:03 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

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

x
QQ截图20171112225719.png
这个ax应该是3吧?为什么是6呢?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-11-13 08:44:24 | 显示全部楼层
调用call命令之后,将下一个指令的地址压栈,先压段地址,然后偏移地址。 在这个命令中,下一个地址是将偏移地址出栈。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-11-25 00:21:56 | 显示全部楼层
本帖最后由 兰陵月 于 2017-11-25 12:25 编辑

图中指令执行流程是这样的。

1、读取CALL S指令;

2、读取CALL S指令后,IP指向CALL S指令的下一条指令,即指令“INC AX”所在位置的偏移地址,此时IP=0x06;

3、执行CALL S指令
(1)将第2项的IP值压入栈中,即将SP减2,并将0x06压入栈中SP所指向的位置;
(2)跳转到目标地址—标号S处执行;

4、执行POP AX。最后一个压入栈的操作就是第3项-(1)的操作,因此弹出也就是栈顶的数—0x06。

所以AX的值等于0x06。


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-25 22:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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