Java教程

实验3 转移指令跳转原理及其简单应用编程

本文主要是介绍实验3 转移指令跳转原理及其简单应用编程,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

实验任务1

源代码:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 assume cs:code, ds:data data segment x db 1, 9, 3 len1 equ $ - x ; 符号常量, $指下一个数据项的偏移地址,这个示例中,是3 y dw 1, 9, 3 len2 equ $ - y ; 符号常量, $指下一个数据项的偏移地址,这个示例中,是9 data ends code segment start: mov ax, data mov ds, ax mov si, offset x ; 取符号x对应的偏移地址0 -> si mov cx, len1 ; 从符号x开始的连续字节数据项个数 -> cx mov ah, 2 s1:mov dl, [si] or dl, 30h int 21h mov dl, ' ' int 21h ; 输出空格 inc si loop s1 mov ah, 2 mov dl, 0ah int 21h ; 换行 mov si, offset y ; 取符号y对应的偏移地址3 -> si mov cx, len2/2 ; 从符号y开始的连续字数据项个数 -> cx mov ah, 2 s2:mov dx, [si] or dl, 30h int 21h mov dl, ' ' int 21h ; 输出空格 add si, 2 loop s2 mov ah, 4ch int 21h code ends end start

 

 

问题1:

line27, 汇编指令 loop s1 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机 器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明 是如何计算得到跳转后标号s1其后指令的偏移地址的。

答:loop s1的机器码为E2F2。跳转的位移量为-14。

loop指令后的第一个字节的偏移地址为:001B,而标号s1处的偏移地址为:000D,位移量=13(000D)-27(001B)=-14(补码表示为F2)。所以其跳转的位移量是-14。

 

问题2:

line44,汇编指令 loop s2 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机 器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明 是如何计算得到跳转后标号s2其后指令的偏移地址的。

答:loop s2的机器码为E2F0。跳转的位移量为-16。

Loop指令后的第一个字节的偏移地址为:0039,而标号s2处的偏移地址为:0029,位移量=41(0029)-57(0039)=-16(补码表示为F0)。所以其跳转的位移量为-16。

实验任务2

复制代码
assume cs:code, ds:data
data segment
    dw 200h, 0h, 230h, 0h
data ends
stack segment
    db 16 dup(0)
stack ends
code segment
start:
    mov ax, data
    mov ds, ax
    mov word ptr ds:[0], offset s1
    mov word ptr ds:[2], offset s2
    mov ds:[4], cs
    mov ax, stack
    mov ss, ax
    mov sp, 16
    call word ptr ds:[0]
s1: pop ax
    call dword ptr ds:[2]
s2: pop bx
    pop cx
    mov ah, 4ch
    int 21h
code ends
end start
复制代码

① 根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,寄存器(ax) = ? 寄存器 (bx) = ? 寄存器(cx) = ?

ax=0021H,bx=0026H,cx=076CH.

问题2:

对源程序进行汇编、链接,得到可执行程序task2.exe。使用debug调试,观察、验证调试 结果与理论分析结果是否一致。

 

 

 

实验任务3

源代码:

assume cs:code, ds:data

data segment
x db 99, 72, 85, 63, 89, 97, 55
len equ $ - x
data ends

code segment
start:
mov ax, data
mov ds, ax
mov ax, 0b800h
mov es, ax
mov bx,0
mov si,0
mov cx,len

s:mov al, [si]
mov ah, 0
call printNumber
add bx, 2
call printSpace
inc bx
inc si
loop s
mov ax, 4c00h
int 21h

printNumber:
mov dl, 10
div dl
or al, 30h
or ah, 30h
mov dh, ah
mov ah, 2
mov dl, al
int 21h
mov dl, dh
int 21h
ret

printSpace:
mov ah, 2
mov dl, ' '
int 21h
ret

code ends
end start

 

实验任务4

源代码:

assume cs:code, ds:data

data segment
    str db 'try'
    len equ $ - str
data ends

code segment
start:
    mov ax, data
    mov ds, ax
    mov dh, 0 
    mov bl, 2
    mov si, 0
    mov ax, 0b800h
    mov es, ax
    call printStr

    mov dh, 24
    mov bl, 4
    mov si, 0
    call printStr
    mov ax,4c00h
    int 21h

printStr:
    mov al, 160
    mul dh

    mov dx, ax
    mov al, bl
    mov bx, dx

    mov cx, len
s:  mov dl, [si]
    mov es:[bx], dl
    inc bx
    mov es:[bx], al
    inc bx
    inc si 
    loop s
    ret

code ends
end start

实验结果:

 

 

实验任务5

源代码:

assume cs:code, ds:data

data segment
stu_no db '20192375030'
    len = $ - stu_no
data ends

code segment
start:
    mov ax, data
    mov ds, ax
    mov ax, 0b800h
    mov es, ax

     mov si, 1
     mov dl, 17h
     mov cx, 2000
  bc:mov es:[si], dl
     add si, 2
    loop bc

     mov dh, 24
     mov al, 160
     mul dh
     mov bx, ax
     call minus

     mov si, 0
     mov cx, len
  s1:mov dl, [si]
     mov es:[bx], dl
     add bx, 2
     inc si
     loop s1

     call minus
     mov ax, 4c00h
     int 21h

 minus:
     mov dl, '-'
     mov cx, 34
   s:mov es:[bx], dl
     add bx, 2
     loop s
     ret
code ends
end start

实验结果:

 

 

这篇关于实验3 转移指令跳转原理及其简单应用编程的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!