实验4 8086标志寄存器及中断

四、实验结论

1. 实验任务1

task1.asm源码:

assume cs:code, ds:data

data segment
   x dw 1020h, 2240h, 9522h, 5060h, 3359h, 6652h, 2530h, 7031h
   y dw 3210h, 5510h, 6066h, 5121h, 8801h, 6210h, 7119h, 3912h
data ends
code segment 
start:
    mov ax, data
    mov ds, ax
    mov si, offset x
    mov di, offset y
    call add128

    mov ah, 4ch
    int 21h

add128:
    push ax
    push cx
    push si
    push di

    sub ax, ax

    mov cx, 8
s:  mov ax, [si]
    adc ax, [di]
    mov [si], ax

    inc si
    inc si
    inc di
    inc di
    loop s

    pop di
    pop si
    pop cx
    pop ax
    ret
code ends
end start

回答问题,line31~line34的4条inc指令,能否替换成如下代码?你的结论的依据/理由是什么:

不能替换。因为inc指令不会改变CF标志位的值,而使用add指令时如果产生进位则会将CF标志位置为1。而且代码中将两数相加时使用的是adc指令,该指令在相加时还要加上CF标志位的值。因此如果改成add指令则在相加时会使结果产生错误。

在debug中调试,观察数据段中做128位加之前和加之后,数据段的值的变化。给出调试观察截图:

 

2. 实验任务2

程序task2.asm源码:

assume cs:code, ds:data
data segment
        str db 80 dup(?)
data ends

code segment
start:  
        mov ax, data
        mov ds, ax
        mov si, 0
s1:        
        mov ah, 1
        int 21h
        mov [si], al
        cmp al, '#'
        je next
        inc si
        jmp s1
next:
        mov ah, 2
        mov dl, 0ah
        int 21h
        
        mov cx, si
        mov si, 0
s2:     mov ah, 2
        mov dl, [si]
        int 21h
        inc si
        loop s2

        mov ah, 4ch
        int 21h
code ends
end start

运行测试截图:

 回答问题:

① 汇编指令代码line11-18,实现的功能是:接收从键盘上输入的字符,存储到si对应的内存单元地址中。如果输入的是#号,则跳转到next程序段。

② 汇编指令代码line20-22,实现的功能是:换行。

③ 汇编指令代码line24-30,实现的功能是:依次输出内存单元中si对应地址的字符。

 

3. 实验任务3

task3.asm源码:

assume cs:code,ds:data
data segment
    x dw 91, 792, 8536, 65521, 2021
    len equ $ - x
data ends
code segment
start:
    mov ax,data
    mov ds,ax
    mov si,0
    mov bx,10
    mov dx,0
    mov cx,len/2
  s:mov ax,[si]
    mov di,0
    call printNumber
    add si,2
    loop s

    mov ah,4ch
    int 21h

    printNumber:
    cmp ax,0
    je print
    mov dx,0
    div bx
    push dx
    inc di
    jmp printNumber

    print:
    cmp di,0
    je printSpace
    pop ax
    mov dl,al
    add dl,30h
    mov ah,2
    int 21h
    sub di,1
    jmp print

    printSpace:
    mov dl,20h
    mov ah,2
    int 21h
    ret
code ends
end start

运行测试截图:

 

4. 实验任务4

task4.asm源码:

assume cs:code,ds:data
data segment
    str db "assembly language, it's not difficult but tedious"
    len equ $ - str
data ends
code segment
start:
    mov ax,data
    mov ds,ax
    mov si,0
    mov cx,len
    mov ah,2
    call strupr
    
    mov ah,4ch
    int 21h

strupr:
    mov dl,[si]
    cmp dl,97
    jb save
    cmp dl,122
    ja save
    and dl,0dfh
    jmp save

save:
    mov [si],dl
    inc si
    loop strupr
    ret
code ends
end start

在debug中调试截图( call strupr 调用之前,数据段的值,以及,调用之后,数据段的值):

 

 

 

 

5. 实验任务5

task5.asm源码:

assume cs:code, ds:data

data segment
    str1 db "yes", '$'
    str2 db "no", '$'
data ends

code segment
start:
    mov ax, data
    mov ds, ax

    mov ah, 1
    int 21h

    mov ah, 2
    mov bh, 0
    mov dh, 24
    mov dl, 70
    int 10h

    cmp al, '7'
    je s1
    mov ah, 9
    mov dx, offset str2
    int 21h

    jmp over

s1: mov ah, 9
    mov dx, offset str1
    int 21h
over:  
    mov ah, 4ch
    int 21h
code ends
end start

程序运行测试截图(输入7,以及输入其他字符,运行结果截图):

 

 程序的功能是:如果输入的字符是'7'则输出"yes",否则输出"no"。

 

6. 实验任务6

程序运行截图:

 

 通过此项实现任务,你对中断、软中断实现机制的理解:中断是CPU检测到的外部或内部发来的特殊信息。CPU遇到中断后不再接着刚才的指令向下执行,而是去处理中断。而软中断是由正在运行的进程产生的。CPU执行int指令时立即产生一个软中断。软中断并不会直接中断CPU。

 

五、实验总结

1.我了解了cmp指令的功能以及je、ja、jb等条件转移指令的功能。它们与cmp配合使用可以实现根据比较结果进行跳转。

2.我知道了将字符串转换为十进制数的方法:运用三十二位或十六位除法依次求出字符串每一位对应的数字,将它们加上30h便是对应十进制数的ASCII码值。将每次求出的数字入栈,再依次出栈并输出就可以得到正确的顺序。

posted @ 2021-12-12 21:06  Romantic2021  阅读(74)  评论(1)    收藏  举报