1. 实验任务1

使用任意文本编辑器,录入汇编源程序task1.asm

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

通过汇编、连接task1.asm得到task1.obj和task1.exe:

 

运行task1.exe,发现有输出结果绿色的NUIST:

 

 

 

使用debug工具对程序进行调试,执行到程序返回前,即line23之前,观察的结果如下图所示:

 

 

 

修改line4里5个字节单元的值,重新汇编、链接、运行,观察结果:

 

 

 

我猜测:数据段中db 5 dup(2)表示定义5个重复字节,数据值都为十进制2,

在loop中使用mov al, [5+si]读出并且输出,用于设置显示颜色。

2表示绿色,3表示蓝色,4表示红色,5表示紫色,6表示橙色

 

2. 实验任务2 

已知数据段data中定义字节数据如下:

data segments
    db 23, 50, 66, 71, 35
data ends

编写代码:

assume cs:code, ds:data
data segment
    db 23,50,66,71,35
data ends
code segment
start:
    mov ax,0810h
    mov es,ax
    mov ax,data
    mov ds,ax
    mov ax,0
    mov si,0
    mov di,0
    mov cx,5
s:    mov al,ds:[di]
    mov bl,10
    div bl
    add al,48
    add ah,48
    mov es:[si],al
    mov es:[si+1],ah
    mov ah,2
    mov dl,es:[si]
    int 21h
    mov ah,2
    mov dl,es:[si+1]
    int 21h
    mov ah,2
    mov dl,32
    int 21h
    add si,2
    inc di
    mov ax,0
    loop s
    mov ah,4ch
    int 21h
code ends
end start

运行结果:

 

 

 

3. 实验任务3

 

 实验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

对task3.asm进行汇编、连接:

 

 

 使用debug工具对task3.exe进行调试:

u命令后输入21是因为一共有4100h个空间

10h  16字节数据段占用空间

10h  16字节堆栈段占用空间

只剩下21h

使用g命令调试:

ds变为076a:

 

 

 

(1)CPU执行程序,程序返回前,data段中的数据为0123h和0456h等,即:

(2)CPU执行程序,程序返回前,cs=076c  ss=076b  ds=076a 

(3)设程序加载后,code段的段地址为X,则data段的段地址为X-2, stack段的段地址为X-1

 

 

4. 实验任务4

实验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

使用d命令查看数据:

 

 (1)CPU执行程序,程序返回前,data段中的数据为0123h和0456h:

 

 (2)CPU执行程序,程序返回前,cs=076c  ss=076b  ds=076a :

 

 (3)设程序加载后,code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1

(4)如果段中的数据占N个字节,则程序加载后,该段实际占有的空间为[1+N/16],([]表示取整)

 

5. 实验任务5

 实验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

 使用d命令查看数据:

(1)CPU执行程序,程序返回前,data段中的数据为0123h和0456h:

 (2)CPU执行程序,程序返回前,cs=076a  ss=076e  ds=076d :

 (3)设程序加载后,code段的段地址为x,则data段的段地址为x+3,stack段的段地址为x+4

 

6. 实验任务6

如果将实验任务3,4,5中的最后一条伪指令“end start”改为“end”(也就是说,不指明程序的入口),则哪个仍然可以正确执行?请说明原因。

实验任务3改后调试:

 

 实验任务4改后调试:

实验任务5改后调试:

 

 结果发现,只有实验任务5的程序还能够正确执行。

因为如果不指明入口位置,程序就会默认以ip=0执行,而不是从start开始执行,而task5.exe的data和stack都在code之后,所以ip本来就为0,可以正确执行。

 

7. 实验任务7

使用任意文本编辑器,录入汇编源程序task7.asm:

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

c segment   
  db 8 dup(0)
c ends

code segment
start:
    mov ax,a
    mov ds,ax
    
    mov ax,c
    mov es,ax
    
    mov bx,0
    mov cx,8
    
s:    
    mov ax,0
    mov al,ds:[bx]
    add al,ds:[bx+16]
    mov es:[bx],al
    inc bx
    loop s

    mov ax,4c00h
    int 21
    
code ends
end start

使用debug工具对task7.exe进行调试:

 

 

 

 

8. 实验任务8

使用任意文本编辑器,录入汇编源程序task8.asm:

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 cx,8
    mov si,0
    mov sp,10h
s: push [si]
    add si,2
    loop s
    mov ax,4c00h
    int 21h
code ends
end start

使用debug工具进行调试:

 

 

 

posted on 2020-11-25 17:05  cox4869  阅读(105)  评论(2编辑  收藏  举报