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


在debug环境中,分别实践、观察:
① add指令对标志寄存器中的零标志位ZF(Zero Flag)、进位标志位CF(Carry Flag)是否有影响?
根据由NZ--ZR和NC--CY的变化可以得出,add对ZF和CF有影响
② inc指令对标志寄存器中的零标志位ZF(Zero Flag)、进位标志位CF(Carry Flag)是否有影响?
根据由NZ--ZR和NC--CY的变化可以得出,inc对ZF有影响,对CF没有影响
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//ax赋值为0 mov cx, 8 s: mov ax, [si] adc ax, [di]//adc改变进位符号 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指令,能否替换成如下代码?你的结论的依据/理由是什么?
add si, 2 add di, 2
未变化之前:


变化之后:

经过实验发现,可以替换为上述代码
在debug中调试,观察数据段中做128位加之前和加之后,数据段的值的变化。给出调试观察截 图。


如图,执行完程序之后数据段的内容已经改变为数据之和。
试验任务二
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//11-18 int 21h mov [si], al cmp al, '#' je next inc si jmp s1 next: mov ah, 2//20-22 mov dl, 0ah int 21h mov cx, si//24-30 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
运行程序,从键盘上输入一串字符,以#结束(比如,输入George Orwell, 1984#),观察结 果。结合运行结果,理解代码并回答问题:

① 汇编指令代码line11-18,实现的功能是?
从DOS中输入一个字符,将其保存在ds:si中,如果输入的字符不是#那么久一直输入下去,如果是#就跳转到next子程序
② 汇编指令代码line20-22,实现的功能是?
换行输出
③ 汇编指令代码line24-30,实现的功能是?
根据输入的字符串长度si,逐个输出单个字符。
试验任务三
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,offset x mov bx,10 mov cx,len/2 s: mov ax,[si] call printNumber call printSpace add si,2 loop s mov ah,4ch int 21h printNumber: push cx mov cx,0 s0: mov dx,0 div bx push dx inc cx cmp ax,0 jne s0 mov ah,2 s1: pop dx or dx,30h int 21h loop s1 pop cx ret printSpace: mov ah,2 mov dl,' ' int 21h ret code ends end start

试验任务四
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, offset str mov cx, len call strupr; mov ax, 4c00h int 21h strupr: mov al, [si] cmp al, 97//小写字母的ASCII范围为97-122 jb s//无符号小于则跳转 cmp al, 122 ja s//无符号大于则跳转 and al, 0dfh mov [si], al s:inc si loop strupr ret code ends end start


试验任务五
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字符相比较,如果不相等则在24行70列输出no,如果相等则在24行70列输出yes
试验任务六
assume cs:code code segment start: ; 42 interrupt routine install code mov ax, cs mov ds, ax mov si, offset int42 ; set ds:si mov ax, 0 mov es, ax mov di, 200h ; set es:di mov cx, offset int42_end - offset int42 cld rep movsb ; set IVT(Interrupt Vector Table) mov ax, 0 mov es, ax mov word ptr es:[42*4], 200h mov word ptr es:[42*4+2], 0 mov ah, 4ch int 21h int42: jmp short int42_start str db "welcome to 2049!" len equ $ - str ; display string "welcome to 2049!" int42_start: mov ax, cs mov ds, ax mov si, 202h mov ax, 0b800h mov es, ax mov di, 24*160 + 32*2 mov cx, len s: mov al, [si] mov es:[di], al mov byte ptr es:[di+1], 2 inc si add di, 2 loop s iret int42_end: nop code ends end start
assume cs:code code segment start: int 42 mov ah, 4ch int 21h code ends end start

程序的中断可分为内中断和外中断,本题实验为内中断,程序通过给出的中断类型码,在中断触发时运行的程序的地址为(N*4) : (N*4+2)号内存中存放的地址寻找新的执行程序,当程序遇到终端类型码,不再执行接下来的代码,而是执行终端代码,再执行完后会返回原位置。
浙公网安备 33010602011771号