鱼C论坛

 找回密码
 立即注册
查看: 1905|回复: 3

[汇编作业] 检测点3.1

[复制链接]
发表于 2022-4-27 06:43:58 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 tyyfly 于 2022-4-27 19:44 编辑

(1)
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=0000, BX=0000;

mov ax,1
mov ds,ax
mov ax,[0000]        ;AX=2662
mov bx,[0001]        ;BX=E626
mov ax,bx                ;AX=E626
mov ax,[0000]        ;AX=2662
mov bx,[0002]        ;BX=D6E6
add ax,bx                ;AX=FD48
add ax,[0004]        ;AX=2C14
mov ax,0                ;AX=0000
mov al,[0002]        ;AX=00E6
mov bx,0                ;BX=0000
mov bl,[000C]        ;BX=0026
add al,bl                ;AX=000C

(2)

                               
登录/注册后可看大图

CS=2000, IP=0000, DS=1000, AX=0000, BX=0000;

mov ax,6622        ;CS=2000, IP=0003, DS=1000, AX=6622, BX=0000
jmp 0ff0:0100        ;CS=0FF0, IP=0100, DS=1000, AX=6622, BX=0000
mov ax,2000        ;CS=0FF0, IP=0103, DS=1000, AX=2000, BX=0000
mov ds,ax                ;CS=0FF0, IP=0105, DS=2000, AX=2000, BX=0000
mov ax,[0008]        ;CS=0FF0, IP=0108, DS=2000, AX=C389, BX=0000
mov ax,[0002]        ;CS=0FF0, IP=010B, DS=2000, AX=EA66, BX=0000

以下是我个人推论,有错误请纠正
由CS控制的信息为程序,由DS控制的信息为数据。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-4-27 10:37:36 | 显示全部楼层
本帖最后由 jackz007 于 2022-4-27 10:39 编辑

(2) CS、DS 、ES、SS 是段地址寄存器,只不过是内存绝对地址的一部分,需要加上偏移才能构成一个完整的 20 位内存地址。一个段可寻址的范围只有 64 kb,CS : IP 固定用于指令地址,SS : SP 固定用于堆栈指针,而 DS、ES 通常用于索引内存数据,CS、DS、ES、SS 既可以相同,也可以不同,一切都取决于程序员对程序内存的组织、规划和安排。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2022-4-27 12:44:29 | 显示全部楼层
jackz007 发表于 2022-4-27 10:37
(2) CS、DS 、ES、SS 是段地址寄存器,只不过是内存绝对地址的一部分,需要加上偏移才能构成一个完整的 20  ...

感谢大大补充,不过这题问的是内存中信息与程序的差异,何时为信息?何时为程序?
小弟我还没认识到SS和ES,以目前刚认识的段寄存器CS与DS中所找到的差异,CS:IP所指向的地址可成为程序,DS则是用来索引内存中的信息,再做读取写入,不知是否有更准确的判断标准?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-5-13 13:58:28 | 显示全部楼层
jackz007 发表于 2022-4-27 10:37
(2) CS、DS 、ES、SS 是段地址寄存器,只不过是内存绝对地址的一部分,需要加上偏移才能构成一个完整的 20  ...

cs和ds如何相同呢,按t单步执行的时候,就是从cs进行执行的,不是从ds开始执行的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-27 16:11

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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