鱼C论坛

 找回密码
 立即注册
查看: 4117|回复: 10

[已解决]为了更好了解指针来学学汇编mov add看不懂,来个大佬解析一遍

[复制链接]
发表于 2021-1-18 18:23:34 | 显示全部楼层 |阅读模式

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

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

x
mov ax ,62627  Ax=____
mov ah ,31H  ,Ax=___
mov a1,23H  Ax=__
......
就是小甲鱼的课后作业
最佳答案
2021-1-19 11:06:41
DongGu.. 发表于 2021-1-19 10:58
第二个,ah不是高位吗,不是应该F4+31,得到最后ax 125A3
还有:
0000:0000 70 80 F0 30 EF 60 30 E2-0 ...


        mov 不是 add,是替换,不是增加。
        debug.exe 的内存地址都是十六进制数,十六进制的 "10" 自然就是十进制的 16 啊。所以,从 debug 中查看内存的时候,每行一律显示的是 16 个字节。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-1-18 18:24:57 | 显示全部楼层
检测点 2.1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-18 18:35:43 | 显示全部楼层
本帖最后由 jackz007 于 2021-1-18 18:37 编辑
mov ax , 62627  ; ax = F4A3H 十进制:62627
mov ah ,   31H  ; ax = 31A3H 十进制:12707
mov al ,   23H  ; ax = 3123H 十进制:12579
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-19 10:58:54 | 显示全部楼层

第二个,ah不是高位吗,不是应该F4+31,得到最后ax 125A3
还有:
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
这0000:0000后面的是啥,不是10个字节,怎么后面超过10个(2个16进制的数)
麻烦你了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-19 11:06:41 | 显示全部楼层    本楼为最佳答案   
DongGu.. 发表于 2021-1-19 10:58
第二个,ah不是高位吗,不是应该F4+31,得到最后ax 125A3
还有:
0000:0000 70 80 F0 30 EF 60 30 E2-0 ...


        mov 不是 add,是替换,不是增加。
        debug.exe 的内存地址都是十六进制数,十六进制的 "10" 自然就是十进制的 16 啊。所以,从 debug 中查看内存的时候,每行一律显示的是 16 个字节。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-19 12:51:09 | 显示全部楼层
刚刚看了原书,就立马跑来说声抱歉了,确实,是mov不是add,草率了,哈哈哈
谢谢你啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-19 12:53:08 | 显示全部楼层
jackz007 发表于 2021-1-19 11:06
mov 不是 add,是替换,不是增加。
        debug.exe 的内存地址都是十六进制数,十六进制的 ...

等我可以加人了,一定关注,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-19 13:50:53 | 显示全部楼层
jackz007 发表于 2021-1-19 11:06
mov 不是 add,是替换,不是增加。
        debug.exe 的内存地址都是十六进制数,十六进制的 ...

(1)  在DEBUG中,用 "D 0:0 lf" 查看内存,结果如下:  

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,写出每条汇编指令执行完后相关寄存器中的值

mov ax,1

mov ds,ax

mov ax,[0000]  ax= 2662H  

mov bx,[0001]  bx= E626H  

mov ax,bx      ax= E626H  

mov ax,[0000]  ax= 2662H  

mov bx,[0002]  bx= D6E6H  

add ax,bx      ax= FD48H  

add ax,[0004]  ax= 2C14H  

mov ax,0       ax=   0   

mov al,[0002]  ax= 00e6H  

mov bx,0       bx=   0   

mov bl,[000c]  bx= 0026H  

add al,bl      ax= 000CH  

我还不是很懂,就堵在这了,这道题如果我的想法,第一空ax=8080
这道题是怎么去找到地址来得到值?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-20 19:24:17 | 显示全部楼层
DongGu.. 发表于 2021-1-19 13:50
(1)  在DEBUG中,用 "D 0:0 lf" 查看内存,结果如下:  

0000:0000 70 80 F0 30 EF 60 30 E2-00 80 80 12 ...

这里的 10 是十六进制
也就是第16个
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-22 00:22:29 | 显示全部楼层
wtchou 发表于 2021-1-20 19:24
这里的 10 是十六进制
也就是第16个

第10个数之后的数,代表什么
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-22 09:31:18 | 显示全部楼层
DongGu.. 发表于 2021-1-22 00:22
第10个数之后的数,代表什么

没代表什么, 就数据而已
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-23 15:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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