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指令不会改变标志寄存器的内容,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
运行测试截图
回答问题 运行程序,从键盘上输入一串字符,以#结束(比如,输入George Orwell, 1984#),观察结 果。结合运行结果,理解代码并回答问题:
① 汇编指令代码line11-18,实现的功能是?
从屏幕中输入一个字符,如果不是#则继续输入,是#则跳到next段
② 汇编指令代码line20-22,实现的功能是?
输出一个换行符
③ 汇编指令代码line24-30,实现的功能是?
从键盘上读取字符直到‘#’结束,并在下一行将读取的字符输出(不包括‘#’)。
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, offset x mov cx, 5 s: push cx mov cx, 0 mov al, ds:[si] mov ah, ds:[si + 1] call printNumber call printSpace pop cx loop s mov ah, 4ch int 21h printNumber: mov bx, 10 mov dx, 0 div bx inc cx push dx cmp ax, 0 jne printNumber s1: mov ah, 2 pop dx or dl, 30h int 21h loop s1 inc si inc si ret printSpace: mov ah, 2 mov dl, ' ' 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, offset str mov cx, len s: mov al, ds:[si] call strupr inc si loop s mov ah, 4ch int 21h strupr: cmp al, 97 jb s1 cmp al, 122 ja s1 and al, 11011111B jmp s1 s1: mov ah, 2 mov dl, al int 21h 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
通过此项实现任务,你对中断、软中断实现机制的理解
我了解到实现中断主要通过设置中断向量与实现函数功能,中断又分为软中断和硬中断,软中断是由程序执行的中断,硬中断是由硬件执行的中断。
task6_1.asm
assume cs:code code segment start: ; 255 interrupt routine install code mov ax, cs mov ds, ax mov si, offset int255 ; set ds:si mov ax, 0 mov es, ax mov di, 200h ; set es:di mov cx, offset int255_end - offset int255 cld rep movsb ; set IVT(Interrupt Vector Table) mov ax, 0 mov es, ax mov word ptr es:[255*4], 200h mov word ptr es:[255*4+2], 0 mov ah, 4ch int 21h int255: jmp short int255_start str db "welcome to 201983290205!" len equ $ - str ; display string "welcome to 201983290455" int255_start: mov ax, cs mov ds, ax mov si, 202h mov ax, 0b800h mov es, ax mov di, 22*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 int255_end: nop code ends end start
task6_2.asm
assume cs:code code segment start: int 255 mov ah, 4ch int 21h code ends end start