实验4 8086标志寄存器及中断
实验任务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 add si, 2 add di, 2 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
答:不能,因为add会影响进位标志位CF,若数据长度较大时,add会改变CF标志位的值,最终将影响后续加法结果的值。
在debug中调试,观察数据段中做128位加之前和加之后,数据段的值的变化。给出调试观察截图。


实验任务二
程序task2.asm源码
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
运行测试截图

回答问题:运行程序,从键盘上输入一串字符,以#结束(比如,输入George Orwell, 1984#),观察结 果。结合运行结果,理解代码并回答问题:
① 汇编指令代码line11-18,实现的功能是?
答:获取键盘输入的值并赋值给ds:[si] ,判断该值是否为 “#”,如果是则跳转至子程序next,如果不是则继续该循环。
② 汇编指令代码line20-22,实现的功能是?
答:输出换行符
③ 汇编指令代码line24-30,实现的功能是?
答:从si=0开始,将ds:[si]中的值输出,循环cx次,其中cx为原始si置0前的值,即输入字符串的长度
实验任务3
ask3.asm源码
assume cs:code, ds:data data segment x dw 91, 792, 8536, 65521, 2021 len equ $ - x data ends stack segment db 20h dup(0) stack ends code segment start : mov ax, data mov ds, ax mov ax, stack mov ss, ax mov sp, 20h mov si, 0 mov cx,5 ;5个数 s0: mov ax,[si] push cx mov cx, 5 ; 每个数最多5位 mov di, 0 ;记录循环次数 call printNumber call printSpace pop cx add si,2 loop s0 mov ah, 4ch int 21h printNumber: s1: inc di mov dx,0 mov bx,10 div bx ; ax存商, dx存余数即要输出的数 push dx push cx ; 用jcxz来判断ax是否为0 mov cx,ax jcxz s2 pop cx loop s1 s2: pop cx ; 此时已经结束本次除法循环,cx的值暂时无用,最后设置为1来跳出除法循环 mov cx, di s3: mov ah, 2 pop bx mov dl, bl or dl, 30h int 21h loop s3 mov cx, 1 ret printSpace: mov ah, 2 mov dl, 20h int 21h ret code ends end start
运行测试截图

实验任务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 stack segment db 20h dup(0) stack ends code segment start : mov ax, data mov ds, ax mov ax, stack mov ss, ax mov sp, 20h mov si, 0 mov cx, 25 call strupr mov ah, 4ch int 21h strupr: s0: mov dx, [si] cmp dl, 'a' jb s1 cmp dl, 'z' ja s1 sub dl, 20h s1: cmp dh, 'a' jb s2 cmp dh, 'z' ja s2 sub dh, 20h s2: mov [si], dx call print add si,2 loop s0 ret print: mov ah, 2 int 21h mov ah, 2 mov dl, dh int 21h ret code ends end start
在debug中调试截图( call strupr 调用之前,数据段的值,以及,调用之后,数据段的值)![]()

实验任务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时,在第24行第70列输出yes,当输入不为7时,在第24行第70列输出no
实验任务6
通过此项实现任务,你对中断、软中断实现机制的理解
答:可以使用中断类型码在中断向量表中找到中断处理程序的入口,找到这个入口地址的最终目的是用它设置CS和IP,使CPU执行中断处理程序。CPU 在收到中断信息后,要对中断信息进行处理,首先引发中断过程。硬件在完成中断过程之后,CS:IP将指向中断处理程序的入口,CPU开始执行中断处理程序。


浙公网安备 33010602011771号