檢測點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的設置
注意:ax中存取的是字型數據,高地址存放高字節,低地址存放低字節!!!
mov ax,1 mov ds,ax # DS=0001H mov ax,[0000] # AX=2662H DS*16+[0000]=00010H 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=0000H mov al,[0002] # AX=00E6H mov bx,0 # BX=0000H mov bl,[000c] # BX=0026H add al,bl # AX=000CH
-
內存中的情況如圖所示:
各寄存器的初始值:
CS=2000H,IP=0,DS=1000H,AX=0,BX=0
;-
寫出CPU執行的指令序列(用匯編指令寫出)。
# 通過CS*16+IP=20000得出第一條指令 mov ax,6622H # IP=IP+3 jmp 0ff0:0100 # 0ff0*16+0100=10000 mov ax,2000H mov ds,ax mov ax,[0008] mov ax,[0002]
-
寫出CPU執行每條指令后,CS,IP和相關寄存器的數值。
指令 CS IP DS AX BX 初值 2000H 0 1000H 0 0 mov ax,6622H 2000H 0003H 1000H 6622H 0 jmp 0ff0:0100 1000H 0 1000H 6622H 0 mov ax,2000H 1000H 0003H 1000H 2000H 0 mov ds,ax 1000H 0005H 2000H 2000H 0 mov ax,[0008] 1000H 0008H 2000H C389H 0 mov ax,[0002] 1000H 000BH 2000H EA66H 0 -
再次體會:數據和程序有區別嗎?如何確定內存中的信息那些是數據,哪些是程序?
如果段地址是
DS
,是數據。如果段地址是
CS
,是指令。
-