实验3 转移指令跳转原理及其简单应用编程
汇编实验3
- 1.实验任务1
- 2.实验任务2
- 3.实验任务3
- 4.实验任务4
- 5.实验任务5
- 实验总结
1.实验任务1
task1.asm
assume cs:code, ds:data
data segment
x db 1, 9, 3
len1 equ $ - x ; 符号常量, $指下一个数据项的偏移地址,这个示例中,是3y dw 1, 9, 3
len2 equ $ - y ; 符号常量, $指下一个数据项的偏移地址,这个示例中,是9
data endscode segment
start:
mov ax, data
mov ds, axmov si, offset x ; 取符号x对应的偏移地址0 -> si
mov cx, len1 ; 从符号x开始的连续字节数据项个数 -> cx
mov ah, 2
s1:mov dl, [si]
or dl, 30h
int 21hmov dl, ' '
int 21h ; 输出空格inc si
loop s1mov 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 21hmov dl, ' '
int 21hadd si, 2
loop s2mov ah, 4ch
int 21h
code ends
end start
① line27, 汇编指令 loop s1 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s1其后指令的偏移地址的。
转移地址 000D 13
执行loop指令后的ip 001B 27
位移量: 13 - 27 = -14;
② line44,汇编指令 loop s2 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s2其后指令的偏移地址的。
转移地址 0029 41
执行loop后的ip 0039 57
位移量: 41 - 57 = -16;
③ 附上上述分析时,在debug中进行调试观察的反汇编截图
2.实验任务2
task2.asm
//task2.asm
assume cs:code, ds:data
data segment
dw 200h, 0h, 230h, 0h
data endsstack segment
db 16 dup(0)
stack endscode segment
start:
mov ax, data
mov ds, axmov word ptr ds:[0], offset s1
mov word ptr ds:[2], offset s2
mov ds:[4], csmov ax, stack
mov ss, ax
mov sp, 16call word ptr ds:[0]
s1: pop axcall dword ptr ds:[2]
s2: pop bx
pop cxmov ah, 4ch
int 21h
code ends
end start
① 根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,寄存器(ax)=0021 寄存器(bx)=0026 寄存器(cx)=076C
② 对源程序进行汇编、链接,得到可执行程序task2.exe。使用debug调试,观察、验证调试结果与理论分析结果是否一致。
3.实验任务3
task3.asm代码如下:
task3.asm
//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
start:
mov ax, data
mov ds, ax
mov si, offset x
mov cx, len
mov bl, 10s:
mov ah, 0
mov al, [si]
call printNumber
call printSpace
inc si
loop smov ax, 4c00h int 21h
printNumber:
div bl
mov dl, al
or dl, 30h
mov bh, ah
mov ah, 2
int 21h
mov dl, bh
or dl, 30h
int 21h
retprintSpace:mov ah, 2
mov dl, 20h
int 21h
retcode ends
end start
4.实验任务4
task4.asm代码如下:
task4.asm
//task4.asm
assume cs:code, ds:data
data segment
str db 'try', 0
data endscode segment
start:
mov ax, data
mov ds, axmov si, offset str mov al, 2 call printStr mov ah, 4ch int 21h
printStr:
push bx
push cx
push si
push dimov bx, 0b800H mov es, bx mov di, 0
s: mov cl, [si]
mov ch, 0
jcxz over
mov ch, al
mov es:[di], cx
inc si
add di, 2
jmp sover: pop di
pop si
pop cx
pop bx
retcode ends
end start
5.实验任务5
task5.asm代码如下:
task5.asm
//task5.asm assume cs:code, ds:data
data segment
stu_no db '201983290082'
len = $ - stu_no
data endscode segment
start:
mov ax, data
mov ds, ax
mov di, 0call printStuNum mov ah, 4ch int 21h
printStuNum:
mov ax, 0b800h
mov es, ax
mov si, 1mov al, 24 mov dl, 80 mul dl mov cx, ax printBlue: mov al, 17h mov es:[si], al add si, 2 loop printBlue sub si, 1 mov ax, 80 sub ax, len mov dl, 2 div dl mov dx, ax mov cx, dx call printSeparator mov cx, len printNumber: mov al, ds:[di] mov ah, 17h mov word ptr es:[si], ax inc di add si, 2 loop printNumber mov cx, dx call printSeparator ret
printSeparator:
mov al, '-'
mov ah, 17h
mov word ptr es:[si], ax
add si, 2
loop printSeparator
retcode ends
end start
实验总结
to be continued......