2、执行以下程序,当执行了“LDS BX,[SI+2]”指令后,DS=?BX=?LDS指令是否可以被“LDS BX,VAR1+2”指令所取代?最后请画出数据段的存储示意图。 DSEG SEGMENT VAR1 DD 12345678H VAR2 DD 23456789H DSEG ENDS CSEG SEGMENT ASSUME CS:CSEG,DS:DSEG START: MOV AX,DSEG MOV DS,AX LEA SI,VAR1 LDS BX,[SI+2] MOV AH,4CH INT 21H CSEG ENDS END START
时间: 2024-01-27 22:06:13 浏览: 121
执行完“LDS BX,[SI+2]”指令后,DS的值不变,仍为DSEG的段地址;而BX的值被设置为VAR1+2的内存地址处的值,即BX=3456789H。
“LDS BX,VAR1+2”指令不能替代“LDS BX,[SI+2]”指令,因为LDS指令将一个内存地址及其所在的段地址装入寄存器,而VAR1+2是一个地址计算表达式,无法直接获取内存地址及其所在的段地址。
数据段的存储示意图如下:
```
+--------+
VAR1: | 78 |
+--------+
| 56 |
+--------+
| 34 |
+--------+
| 12 |
+--------+
VAR2: | 89 |
+--------+
| 67 |
+--------+
| 45 |
+--------+
| 23 |
+--------+
```
相关问题
已知(DS)=3000H, (BX)=1000H, (SI)=0020H, 内存分配如图所示LEA DI,[BX+SI+0300H]MOV AX,[DI]LDS SI,[BX+DI]SUB AX,1234H连续执行上述指令后, (DS)=_①__,(SI)= ② ,(BX)= ③ ,(DI)= _④ ,(AX)= ⑤__
根据题意,我们可以模拟一遍程序执行过程:
1. LEA DI,[BX+SI+0300H]:将 DI 寄存器的值设置为 BX+SI+0300H 的地址,即 DI=1000H+0020H+0300H=1320H。
2. MOV AX,[DI]:将 DI 指向的内存单元的值读入 AX 寄存器,即 AX=[1320H]=xxxxH(假设值为 xxxxH)。
3. LDS SI,[BX+DI]:将 DS 寄存器的值设置为 [BX+DI] 指向的内存单元中的段地址,SI 寄存器的值设置为该内存单元中的偏移地址。因为 BX=1000H,DI=1320H,所以 [BX+DI]=[1000H+1320H]=2320H,其中 2320H 的高 16 位是段地址,低 16 位是偏移地址。所以 DS=23H,SI=20H。
4. SUB AX,1234H:将 AX 寄存器的值减去 1234H,即 AX=xxxxH-1234H=yyyyH。
5. 程序结束。
根据上述过程,可得出以下结果:
① DS=23H
② SI=20H
③ BX=1000H
④ DI=1320H
⑤ AX=yyyyH
在实模式下,假设(DS)=1234H,(SI)=124H,(12464H)=30ABH,(12484H)=464H,有以下程序段: LEA SI,[SI] MOV AX,[BX] MOV [SI+22H],1200H LDS SI,[SI+20H] ADD AX,[SI] 上述程序段执行后 (DS)= , (SI)= , (AX)= 。
根据程序段执行后的结果,我们可以逆推出程序执行前的内存状态。
首先,LEA指令将SI的值更新为[SI],即124H处的值30ABH。因此,此时(SI)=30ABH。
接着,MOV AX,[BX]将[BX]处的值读入AX寄存器。由于程序段中没有给出[BX]的值,我们无法确定AX的值。
然后,MOV [SI+22H],1200H将1200H写入[SI+22H]处,即30ABH+22H=30CDH处。因此,此时(30CDH)=1200H。
继续执行,LDS SI,[SI+20H]指令将[SI+20H]处的值作为地址加载到DS:SI中。由于此时(SI)=30ABH,因此DS:SI指向(30ABH+20H)=30CBH处的内存单元。根据该内存单元中的值,将DS设置为464H,SI设置为1234H。因此,此时(DS)=464H,(SI)=1234H。
最后,ADD AX,[SI]将AX和[SI]处的值相加,并将结果存回AX中。由于此时(SI)=1234H,因此[SI]处的值为(1234H)=464H。因此,AX的值为原来的值加上464H。
综上所述,程序段执行后,(DS)=464H,(SI)=1234H,(AX)的值取决于[BX]的值,无法确定。
阅读全文