任務一:
1. 補全程序 t1.asm,完成在屏幕上輸出內存單元中的十進制兩位
; 在屏幕上輸出內存單元中的十進制兩位數
assume cs:code, ds:data
data segment
db 12
db 0,0 ; 前一個字節用於保存商,後一個字節用於保存餘數
data ends
code segment
start:
mov ax,data
mov ds,ax ; 補全指令,使得ds <-- data段地址
mov ah,0
mov al,ds:[0] ; ax <-- data段字節單元的被除數12
mov bl,10
div bl
mov ds:[2],al ; 補全代碼,讓商保存到data段註釋中指定的單元
mov ds:[3],ah ; 補全代碼,讓餘數保存到data段註釋中指定的單元
mov ah,2
mov dl,ds:[2] ; 補全代碼,使得dl <-- data段中保存的商的字節單元數值
add dl,30h ; 補全代碼,使得dl中的數值轉換爲數字字符
int 21h
mov ah,2
mov dl,ds:[3] ; 補全代碼,使得dl <-- data段中保存餘數的字節單元數值
add dl,30h ; 補全代碼,使得dl中的數值轉換爲數字字符
int 21h
mov ax,4c00h
int 21h
code ends
end start
效果截圖:
任務二:2. 補全程序 t2.asm,完成在屏幕上輸出 data 段定義的 5 個十進制兩位數,數據和數據 之間以空格間隔。
assume cs:code, ds:data
data segment
db 12,35,96,55,67
db 10 dup (0)
data ends
code segment
start: mov ax,data
mov ds,ax
mov bx,0
mov cx,5
;5個數據循環5次
s: mov al,ds:[bx] ;ax中依次放入數據段數據(字節型)
mov ah,0
mov dl,10
div dl ;爲了實現十進制輸出
or ah,00110000b ;將數字轉化爲數字字符
or al,00110000b
mov ds:[bx+5],al ;將商暫存在事先定義的數據段中
mov ds:[bx+6],ah ;將餘數暫存在事先定義的數據段中
mov ah,2
mov dl,ds:[bx+5]
int 21h
mov ah,2
mov dl,ds:[bx+6]
int 21
;輸出空格
mov ah,2
mov dl,' '
int 21h
inc bx ;每次bx+1(字節型),循環
loop s
mov ax,4c00h
int 21h
code ends
end start
效果截圖:
任務三:
; p187 實驗9
assume ds:data, cs:code
data segment
db 'welcome to masm!'
db 2H,24H,71H ;字符串屬性值
data ends
code segment
start: mov ax,data
mov ds,ax ;字符串及屬性值所在段的段地址送入ds
mov ax,0b800H
mov es,ax ;80×25彩色字符模式顯示緩衝區段地址送入es
mov di,16
mov si,06e0h
mov cx,3
s0: push cx
mov cx,16
mov bx,0
s1: mov al,ds:[bx] ;字符
mov ah,ds:[di] ;屬性
mov es:[si],al
mov es:[si+1],ah
inc bx ;依次後移字符
add si,2 ;依次後移在屏幕中輸出的位置
loop s1
pop cx
inc di ;改變屬性
add si,80h ;換行
loop s0
mov ax,4c00h
int 21h
code ends
end start
效果截圖:
實驗心得:
這次的實驗需要思考的地方比較多,首先是在屏幕輸出字符的方式:
mov ah,2
mov dl,要輸入的字符或對應的ASCII碼值
int 21h
其次80x25彩色字符模式顯示緩衝區的結構花費了我一定的時間去了解,在一行中,一個字符佔用兩個字節存儲空間,低位字節存儲字符的ASCII碼值,高位字符存儲字符的屬性。一行共有80個字符,即160個字節。