实验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
回答问题
2、line31~line34的4条inc指令,能否替换成如下代码?你的结论的依据/理由是什么?
add si, 2 add di, 2
答:不可以。inc指令不修改CF的值,add指令可能改变标志CF的值,而前面adc指令需要用到CF的值,所以不可以代替。
3、在debug中调试,观察数据段中做128位加之前和加之后,数据段的值的变化。给出调试观察截图:

实验任务2
1、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
2、运行测试截图

3、回答问题
运行程序,从键盘上输入一串字符,以#结束(比如,输入George Orwell, 1984#),观察结果。结合运行结果,理解代码并回答问题:
① 汇编指令代码line11-18,实现的功能是: 将输入的字符储存到data数据段内,并且遇到'#'跳出输入
② 汇编指令代码line20-22,实现的功能是:0AH是换行符的ASCII码,在屏幕上进行换行操作
③ 汇编指令代码line24-30,实现的功能是:将data数据段内的字符打印到屏幕上
实验任务3
1、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 dl,48 mov dx,0 mov bx,10 mov cx,len/2 mov si,0 s:mov ax,ds:[si] mov di,0 call printNum call printSpace add si,2 loop s mov ah,4CH int 21H printNum: cmp ax,0 je ot1 div bx push dx mov dx,0 inc di jmp printNum ot1:cmp di,0 jne sh ret sh: pop ax mov ah,2 add al,48 mov dl,al int 21h dec di jmp ot1 printSpace: mov ah,2 mov dl,0 int 21h ret code ends end start
2、运行测试截图
实验任务4
1、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 cx,len mov si,0 mov ax,0b800h mov es,ax mov di,0 call strupr mov ah,4ch int 21h strupr: mov dl,ds:[si] cmp si,cx je jmpout cmp dl,'a' jb show_str cmp dl,'z' ja show_str and dl,11011111B show_str: mov es:[di],dl inc si add di,2 jmp strupr jmpout: ret code ends end start
2、在debug中调试截图( call strupr 调用之前,数据段的值,以及,调用之后,数据段的值)

实验任务5
1、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
2、程序运行测试截图(输入7,以及输入其他字符,运行结果截图)

3、程序的功能是?
比较输入字符的ASCLL值是否与7的ASCLL值相等
实验任务6
通过此项实现任务,你对中断、软中断实现机制的理解
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

中断处理程序:
由于cpu随时都有可能检测到中断信息,也就是说cpu随时都要执行中断处理程序,所以,中断处理程序必须一致存储在内存某段空间中。
cpu执行完中断处理程序以后,必须返回到原来的地址继续执行后面的内容,所以,在执行中断处理程序之前必须记录下原来执行指令的地址,便于中断处理完以后返回。
实验总结
1、2号子功能:
mov ah, 2
mov dl, XX
int 21h
2、div指令:如果除数B是16位,那么除法的结果: AX保存商,DX保存余数。
3、三种主要跳转指令:无条件跳转(jmp);根据CX寄存器值跳转(jcxz);根据寄存器标志位跳转(je、jne、jz...)
浙公网安备 33010602011771号