STL原始碼分析(二)
阿新 • • 發佈:2020-11-26
試驗1
使用文字編輯器,編寫程式碼,具體如下:
assume cs:code, ds:data data segment db 'Nuist' db 5 dup(2) data ends code segment start:mov ax, data mov ds, ax mov ax, 0b800H mov es, ax mov cx, 5 mov si, 0 mov di, 0f00h s: mov al, [si] and al, 0dfh mov es:[di], al mov al, [5+si] mov es:[di+1], al inc si add di, 2 loop s mov ah, 4ch int 21h code ends end start
執行後可以見到在坐下方出現了綠色的NUIST
使用debug工具進行反彙編,得到
讓程式執行到0027的位置
將db 5 dup(2)修改引數後,發現出現的了不同顏色的nuist,說明該資料段控制輸出字元的顏色
試驗2
程式碼書寫如下:
assume cs:code, ds:data data segment db 23, 50, 66, 71, 35 data ends code segment start: mov ax, data mov ds, ax mov dl,10 mov cx, 5 mov si, 0 s: mov ax,0 mov al, [si] div dl mov bx,ax mov ah,2 mov dl,bl or dl,48 int 21h mov dl,bh or dl,48 int 21h mov dl,32 int 21h inc si loop s mov ah, 4ch int 21h code ends end start
執行得到結果
試驗3
程式碼書寫如下:
assume cs:code, ds:data, ss:stack data segment dw 0123h, 0456h, 0789h, 0abch, 0defh, 0fedh, 0cbah, 0987h data ends stack segment dw 0, 0, 0, 0, 0, 0, 0, 0 stack ends code segment start: mov ax,stack mov ss, ax mov sp,16 mov ax, data mov ds, ax push ds:[0] push ds:[2] pop ds:[2] pop ds:[0] mov ax,4c00h int 21h code ends end start
回答以下問題:
- CPU執行程式,程式返回前,data段中的資料為:23 01 56 04 89 07 bc 0a ef 0d ed 0f ba 0c 87 09
- CPU執行程式,程式返回前,cs = 076ch, ss = 076bh,ds = 076ah
- 設程式載入後,code段的地址為X,則data段的段地址為X-2,stack段的段地址為X-1
試驗4
程式碼書寫如下:
assume cs:code, ds:data, ss:stack
data segment
dw 0123h, 0456h
data ends
stack segment
dw 0, 0
stack ends
code segment
start: mov ax,stack
mov ss, ax
mov sp,16
mov ax, data
mov ds, ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax,4c00h
int 21h
code ends
end start
回答以下問題:
- CPU執行程式,程式返回前,data段中的資料為:23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00
- CPU執行程式,程式返回前,cs = 076ch, ss = 076bh,ds = 076ah
- 設程式載入後,code段的地址為X,則data段的段地址為X-2,stack段的段地址為X-1
- 對於如下定義的段,如果段中資料佔N個位元組,則程式載入之後,該段實際佔有的空間為 ((N-1)/16+1)*16 位元組
name segment
...
name ends
試驗5
書寫程式碼如下:
assume cs:code, ds:data, ss:stack
code segment
start: mov ax,stack
mov ss, ax
mov sp,16
mov ax, data
mov ds, ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax,4c00h
int 21h
code ends
data segment
dw 0123h, 0456h
data ends
stack segment
dw 0,0
stack ends
end start
回答以下問題:
- CPU執行程式,程式返回前,data段中的資料為:23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00
- CPU執行程式,程式返回前,cs = 076ah, ss = 076eh,ds = 076dh
- 設程式載入後,code段的地址為X,則data段的段地址為X+3,stack段的段地址為X+4
試驗6
根據實驗情況,回答問題 “ 如果將(1)、(2)、(3)題中的最後一條偽指令“end start”改為“end”(也就是說不指明程式的入口),則哪個程式仍然可以正確執行?請說明原因。”
- 只有task5(即(3))中的程式可以正常執行,因為程式是預設從開頭開始執行,(3)的程式碼段正好在前面,可以執行,而(1)、(2)的資料段在前面不能執行,會發生錯誤。
試驗7
書寫程式碼如下
assume cs:code
a segment
db 1,2,3,4,5,6,7,8
a ends
b segment
db 1,2,3,4,5,6,7,8
b ends
c1 segment ; 在整合軟體環境中,請將此處的段名稱由c→改為c1或其它名稱
db 8 dup(0)
c1 ends
code segment
start:
mov ax,a
mov ds,ax
mov ax,b
mov es,ax
mov ax,c1
mov ss,ax
mov sp,8
mov cx,4
mov bx,6
s:
mov ax,[bx]
add ax,es:[bx]
push ax
sub bx,2
loop s
mov ah, 4ch
int 21h
code ends
end start
使用debug工具檢視C段資料為 02 04 06 08 0a 0c 0e 10 。
試驗8
書寫程式碼如下
assume cs:code
a segment
dw 1,2,3,4,5,6,7,8,9,0ah,0bh,0ch,0dh,0eh,0fh,0ffh
a ends
b segment
dw 8 dup(0)
b ends
code segment
start:
mov ax,a
mov ds,ax
mov ax,b
mov ss,ax
mov sp,16
mov cx,8
mov bx,0
s:
push [bx]
add bx,2
loop s
mov ah, 4ch
int 21h
code ends
end start