鱼C论坛

 找回密码
 立即注册
查看: 3370|回复: 7

[汇编作业] 检测点10.3请各位帮忙看一下

[复制链接]
发表于 2019-2-9 23:20:50 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 清风2012 于 2019-2-10 20:30 编辑


下面的程序执行后,ax中的数值为多少


内存地址    机器码                           汇编指令

1000:0       b8 00 00                        mov ax, 0
1000:3       9A 09 00 00 10               call far ptr s
1000:8       40                                  inc ax
1000:9       58                                  s:pop ax
                                                      add ax, ax
                                                      pop bx
                                                      add ax, bx
我算出来的ax的值是------1006

我的计算过程是这样的:当IP=0,执行mov ax, 0; 当该指令执行完后,IP=3
                                   当IP=3,执行call far ptr s; 该指令在执行的过程中,当前CS=1000,IP=3,执行CS和IP的入栈操作并跳转到标号s
                                   当IP=9,执行pop ax (ax=3)
                                                   执行add ax, ax (ax=6)
                                                执行pop bx (bx=1000)
                                                执行add ax, bx (ax=1006)

我看了其他答案,最终ax的值是1010h. 哪一个才是正确的?----------是1010?还是1006?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-2-10 00:45:42 | 显示全部楼层
本帖最后由 jackz007 于 2019-2-10 00:48 编辑

         向人求助还向人索钱?有没有搞错,别人是从你这里得好处了还是欠你了?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-2-10 09:16:04 | 显示全部楼层
兄弟你弄错了吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-2-11 12:27:21 | 显示全部楼层

回帖奖励 +5 鱼币

本帖最后由 jackz007 于 2019-2-11 13:14 编辑

      执行 CALL 指令时会把下一条指令的地址压栈,就楼主的情形而言,入栈的地址是 1000:8,也就是从函数调用返回后,即将执行的下一条指令的地址
1000:8       40                                  inc ax

      所以,ax 的最终值应该是 1010
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-2-16 12:54:00 | 显示全部楼层

回帖奖励 +5 鱼币

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

使用道具 举报

发表于 2019-2-16 13:15:43 | 显示全部楼层
弄错了吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-5 11:58:16 | 显示全部楼层

回帖奖励 +5 鱼币

assume cs: code

        stack segment
                db 16 dup (0)
        stack ends
       
        code segment
                start:        ;mov ax, stack
                                ;mov ss,        ax
                                ;mov sp, 10h
                                mov ax, 0
                                call far ptr s
                                inc ax
                s:                pop ax
                                add ax, ax
                                pop bx
                                add ax, bx
                               
                                mov ax, 4c00h
                                int 21h
               
        code ends
       
end start
       
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-5 12:00:32 | 显示全部楼层
先把注释去掉用debug调试,然后再把注释加上调试 就明白了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 03:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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