实验一:

  在屏幕上输出内存单元中的两位数。

 

; 在屏幕上输出内存单元中的十进制两位数
assume cs:code, ds:data
data segment
     db 12
     db ?,?   ; 前一个字节用于保存商,后一个字节用于保存余数
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:[1],al    ; 补全代码,让商保存到data段注释中指定的单元
      mov  ds:[2],ah    ; 补全代码,让余数保存到data段注释中指定的单元

      mov ah,2
      mov dl,ds:[1]   ; 补全代码,使得dl <-- data段中保存的商的字节单元数值
      add dl,48       ; 补全代码,使得dl中的数值转换为数字字符
      int 21h

      mov ah,2
      mov dl,ds:[2]     ; 补全代码,使得dl <-- data段中保存余数的字节单元数值
      add dl,48        ; 补全代码,使得dl中的数值转换为数字字符      
      int 21h

      mov ax,4c00h
      int 21h
code ends
end start

 

  本题的思路十分的简单就只要将商和余数分别保存在低位和高位,然后调用系统函数进行输出即可。

实验二:

  实验二和实验一差不多,由原来的输出一个数变成输出5个数。这里就不在赘述了。

assume cs:code, ds:data
data segment
     db 12,35,96,55,67
data ends
code segment
start:
      ; 补全程序,参考t1.asm,综合应用以下知识完成:
      ; (1) loop指令、内存单元地址的灵活表示
      ; (2) div指令, 数字→数字字符的转换
      ; (3) int 21h的2号子功能,完成单个字符输出的方法,即: 
      ;     mov ah,2
      ;     mov dl,待输出字符或其ASCⅡ码
      ;     int 21h
      ; (4) 数据和数据之间以空格间隔的实现: 使用(3)输出空格字符


      mov ax, data
      mov ds, ax

      mov cx, 5
      mov di, 0

 s:   mov ah,0
      mov al,ds:[di]
      mov bl,10
      div bl
      mov  ds:[5],al  
      mov  ds:[6],ah   

      mov ah,2
      mov dl,ds:[5]  
      add dl,48      
      int 21h

      mov ah,2
      mov dl,ds:[6]    
      add dl,48       
      int 21h

      mov ah,2
      mov dl,32
      int 21h

      add di,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 bx, 0
        mov si, 1
        mov bp, 0
        mov cx, 16
s1:
        mov dl, ds:[bp]
        mov es:[bx], dl
        mov dl, ds:[10]
        mov es:[si], dl
        add bx, 2
        add si, 2
        add bp,1
        loop s1

        mov bx, 40
        mov si,  41
        mov bp, 0
        mov cx, 16
s2:
        mov dl, ds:[bp]
        mov es:[bx], dl
        mov dl, ds:[11]
        mov es:[si], dl
        add bx, 2
        add si, 2
        add bp,1
        loop s2

        mov bx, 80
        mov si,  81
        mov bp, 0
        mov cx, 16
s3:
        mov dl, ds:[bp]
        mov es:[bx], dl
        mov dl, ds:[12]
        mov es:[si], dl
        add bx, 2
        add si, 2
        add bp,1
        loop s3
        

        mov ax,4c00h
        int 21h
code ends
end start

  

然后丑点就丑点把,每去算它们显示在屏幕上的位置。