实验四

实验一

代码:

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

截图:

软中断类似于自己定义的函数,而中断像是系统调用函数。

 

实验总结

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

posted @ 2021-12-14 15:00  随影ys  阅读(80)  评论(1)    收藏  举报