鱼C论坛

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

[已解决]汇编语言书中有个地方不太懂,请大神指教。。

[复制链接]
发表于 2020-12-20 23:13:21 | 显示全部楼层 |阅读模式

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

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

x
检测点3.1原题目:
在Debug中 用"d 0:0 1f" 查看内存,结果如下:
0000:0000 70 80 F0 30 EF 60 30 E2-00 80 80 12 66 20 22 60
0000:0010 62 26 E6 D6 CC 2E 3C 3B-AB BA 00 00 26 06 66 88
下面的程序执行前,AX=0,BX=0,写出每条汇编指令执行完后相关寄存器中的值。
提示:注意DS的设置
mov ax,1
mov ds,ax  
mov ax,[0000]

计算过程:
mov ax,1                        //ax=0001
mov ds,ax                  //ds=0001
mov ax,[0000]                /[0000]的地址应该是0001:0000吧??为什么会是0000:0010???

回显应该是段地址:偏移地址吧?
上机验证时0000:0010,百思不得其解啊


最佳答案
2020-12-20 23:24:34
本帖最后由 jackz007 于 2020-12-20 23:27 编辑

        你说得没错,0001:0000  和 0000:0010 虽然在形式上有所不同,但实际上确实是同一个地址,因为,SEG : OFF 形式的内存地址如果要换算成 20 位形式的话,计算公式是:
        SEG × 10H + OFF
        用这个公式的计算结果,上述两个地址的 20 位形式的内存地址相等,都是 00010H
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-12-20 23:24:34 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2020-12-20 23:27 编辑

        你说得没错,0001:0000  和 0000:0010 虽然在形式上有所不同,但实际上确实是同一个地址,因为,SEG : OFF 形式的内存地址如果要换算成 20 位形式的话,计算公式是:
        SEG × 10H + OFF
        用这个公式的计算结果,上述两个地址的 20 位形式的内存地址相等,都是 00010H
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-12-21 09:36:45 | 显示全部楼层
感谢大佬指点
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-23 18:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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