实验四
实验一
代码:
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
1.add指令对标志寄存器中的零标志位和进位标志位都有影响

2.inc指令对标志寄存器中的零标志位有影响,对进位标志位没有影响

1.不能换成add指令代码,因为使用add指令会影响CF进位寄存器,使得刚才进行的16位假发的进位失准,对后续进一步的加法计算造成影响。
2.
运行前:

运行后:

实验二
代码:
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
截图:

1.进行字符输入并判断输入是否为#,若为#,则跳转至next标号处,若否,则程序跳转至开头,继续输入
2.进行换行输出
3.对已存入数据段的数据进行顺序输出,#虽然存在数据段中,但是由于是将si赋值给了cx,即cx中实际上是偏移地址,而非真正的输入次数,所以最后一个符号被自动忽略。
实验三
代码:
assume cs:code, ds:data, ss:stack data segment x dw 91, 792, 8536, 65521, 2021 len equ $ - x data ends stack segment db 16 dup(0) stack ends code segment start:mov ax,data mov ds,ax mov si,0 mov cx,len/2 s: push cx mov ax,[si] call printNumber call printSpace add si,2 pop cx loop s mov ah,4ch int 21h
printNumber:mov bx,10 mov cx,0 mov dx,0
s1: div bx add dx,30h push dx inc cx mov dx,cx mov cx,ax jcxz s2 mov cx,dx mov dx,0 jmp s1 s2: mov cx,dx s3: mov ah,2h pop dx int 21h loop s3 ret printSpace:mov ah,2h 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,0 mov cx,str call strupr mov ah,4ch int 21h
strupr:mov dx,cx mov cl,[si] mov ch,0 sub cx,20h jcxz s sub cx,7h jcxz s sub cx,5h jcxz s mov al,[si] and al,11011111b mov [si],al s: inc si mov cx,dx 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:

输入其他字符:

程序的功能是判断输入值是否为7,若为7,则输出‘yes’,若否,则输出‘no’。
并将输出结果定位到第0页第24行第70列(用到了显存的知识)
实验六
6_1代码:
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
6_2代码:
assume cs:code code segment start: int 42 mov ah, 4ch int 21h code ends end start
截图:

软中断类似于自己定义的函数,而中断像是系统调用函数。
实验总结
本次实验是综合了前几次实验及添加了新学习到的标志寄存器和中断的知识的综合体,其中最主要的我认为还是两类,一个是学会使用跳转指令,无论是有条件跳转还是无条件跳转,还有一个就是综合寻址方式,利用好各类寄存器。最后,在对寄存器进行赋值操作时,必须先保证寄存器间的位数保持一致,就如高级语言的类型一致一样。

浙公网安备 33010602011771号