实验3 转移指令跳转原理及其简单应用编程
实验任务1
task1.asm
assume cs:code, ds:data
data segment
x db 1, 9, 3;定义一个x[3]的数组
len1 equ $ - x;$为下一个数据项偏移地址
y dw 1, 9, 3
len2 equ $ - y
data ends
code segment
start:
mov ax, data
mov ds, ax
mov si, offset x
mov cx, len1
mov ah, 2;int 21h根据ah中的数据进行操作02为显示输出
s1:mov dl, [si]
or dl, 30h;将dl中数据转换为ascii码值,02在调用字符时,用的是ascii值
int 21h
mov dl, ' '
int 21h
inc si
loop s1
mov ah, 2
mov dl, 0ah
int 21h
mov si, offset y
mov cx, len2/2
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
实验结果
回答问题
① line27, 汇编指令loop s1跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s1其后指令的偏移地址的。
跳转的位移量是-14。loop指令为循环指令是短转移,在对应的机器码中包含转移的位移,cpu计算当前地址到标号地址的位移量,直接加在ip之后,loop指令执行之后IP变成001B,需要跳转到000D,所以偏移量为-14。
② line44,汇编指令loop s2跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s2其后指令的偏移地址的。
跳转的位移量是-10,标号s2的偏移地址为0029,loop指令后第一个字节的偏移地址为0039,两者相减结果为-10。包括loop指令在内的所有循环指令都是短转移,在对应机器码中包含转移位移而非地址。
实验任务2
task2.asm
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) = 0021h 寄存器(bx) = 0026h 寄存器(cx) = 076ch
offset分别将s1,s2处地址传入偏移量为ds:[0]和ds:[2],第一次call指令执行,将下一条指令,即s1处地址入栈,并跳转至ds:[0]中地址即s1处,执行pop指令将栈中s1的地址传给ax,第二次同理,不过入栈双字长度,即入栈下一条指令的段地址和偏移地址。ax中存放了s1处指令,在内存中的偏移地址,bx中存放了标号s2处指令在内存中的偏移地址,cx中存放了s2处指令,在内存中的段地址。
实验任务3
task3.asm
assume cs:code, ds:data
data segment
x db 99,72,85,63,89,97,55
len equ $-x
data ends
code segment ;除数是8位,则AL存储除法操作的商,AH存储除法操作的余数
start:
mov ax,data
mov ds,ax
mov byte ptr bl,10
mov si,offset x
mov cx,len
s: mov al,ds:[si]
mov ah,0
div bl
call printNumber
call printSpace
inc si
loop s
mov ah,4ch
int 21h
printNumber:
mov dx,ax
mov ah,2
or dl,30h
int 21h
mov dl,dh
or dl,30h
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 cx,len
mov si,offset str
mov bh,0
mov bl,2
call printStr
mov cx,len
mov si,offset str
mov bh,24
mov bl,4
call printStr
mov ah,4ch
int 21h
printStr:
;计算行对应段地址
mov al,0ah
mul bh
add ax,0b800h
mov es,ax
mov di,si
;写入显存
s: mov al,ds:[si]
mov ah,bl
mov es:[di],ax
inc si
add di,2
loop s
ret
code ends
end start
实验结果
实验任务5
assume cs:code,ds:data
data segment
stu_no db '201983290204'
len = $-stu_no
data ends
stack segment
db 16 dup(0)
stack ends
code segment
start:
mov ax,data
mov ds,ax
mov ax,stack
mov ss,ax
mov sp,16
mov si,0
call setColor
call setLine
call setNo
mov ah,4ch
int 21h
setColor:
mov ax,0b800h
mov es,ax
mov ax,0
mov al,25
mov dl,80
mul dl
mov di,0
mov bl,00010000B
mov dl,20h
mov cx,ax
s: mov es:[di],dl
inc di
mov es:[di],bl
inc di
loop s
ret
setLine:
mov ax,0b800h
mov es,ax
mov ax,0
mov al,24
mov dx,160
mul dx
mov di,ax
mov dl,2dh
mov bl,00010111B
mov cx,80
p: mov es:[di],dl
inc di
mov es:[di],bl
inc di
loop p
ret
setNo:
mov ax,0b800h
mov es,ax
mov ax,0
mov al,24
mov dx,160
mul dx
mov di,ax
mov ax,68
add di,ax
mov bl,00010111B
mov cx,len
q: mov ax,ds:[si]
mov es:[di],ax
inc di
mov es:[di],bl
inc di
inc si
loop q
ret
code ends
end start
实验结果