实验3 转移指令跳转原理及其简单应用编程
1. 实验任务1
此部分书写内容:
给出程序task1.asm源码,及,运行截图
assume cs:code, ds:data data segment x db 1, 9, 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 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 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其后指令的偏移地址的。
F2表示的是位移量的补码,其二进制形式为11110010,补码为10001110,即-14。又当前IP+有符号偏移量=偏移地址。可验证001B(16进制)-14(10进制)=000D(16进制)。
回答问题②
② line44,汇编指令loop s2跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s2其后指令的偏移地址的。
同问题1,F0,二进制形式为11110000,补码为10010000,即-16。又0039-0010=0029。可验证得位移量为-16。
2. 实验任务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
给出分析、调试、验证后,寄存器(ax) = ? (bx) = ? (cx) = ? 附上调试结果界面截图。
① 根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,寄存器(ax) = ? 寄存器(bx) = ? 寄存器(cx) = ?
1.call word ptr将下一条指令的偏移地址压入栈,再跳转到相应地址执行命令。call dword ptr 先将下一条指令的段地址压入栈,再将下一条指令的偏移地址压入栈,再跳转到相应地址执行命令。
2.本题ds:[0]中存放的是s1的偏移地址,ds:[2]中存放的是s2的偏移地址,所以第一个call指令先将s1的偏移地址压入栈,在跳转到s1处执行pop ax,即将s1的偏移地址0021出栈并存放到ax。第二个call指令先将s2处的偏移地址压入栈,再将s2处的段地址压入栈,再跳转到ds:[2]即s2处执行pop bx,即将s2的偏移地址0026出栈并存放到bx,再执行pop cx,即将s2的段地址076C出栈并存放到cx中。
即ax=0021,bx=0026,cx=076C
② 对源程序进行汇编、链接,得到可执行程序task2.exe。使用debug调试,观察、验证调试结果与理论分析结果是否一致。
3. 实验任务3
此部分书写内容:
给出程序源码task3.asm
assume ds:data, cs:code
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 byte ptr ds:[10], 10
s1: mov ah, 0
mov al, ds:[si]
div byte ptr ds:[10]
call printNumber
call printSpace
inc si
loop s1
mov ax, 4c00h
int 21h
printNumber:mov bx, ax
or bl, 30h
or bh, 30h
mov ah, 2
mov dl, bl
int 21h
mov dl, bh
int 21h
ret
printSpace:mov ah, 2
mov dl, ' '
int 21h
ret
code ends
end start
运行测试截图
4. 实验任务4
此部分书写内容:
给出程序源码task4.asm
assume ds:data, cs:code 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 byte ptr ds:[10], 10 s1: mov ah, 0 mov al, ds:[si] div byte ptr ds:[10] call printNumber call printSpace inc si loop s1 mov ax, 4c00h int 21h printNumber:mov bx, ax or bl, 30h or bh, 30h mov ah, 2 mov dl, bl int 21h mov dl, bh int 21h ret printSpace:mov ah, 2 mov dl, ' ' int 21h ret code ends end start
运行测试截图
5. 实验任务5
此部分书写内容:
给出程序源码
assume ds:data, cs:code data segment stu_no db '201913420007' len = $ - stu_no data ends code segment start: mov ax, data mov ds, ax mov cx, 4000 mov si, offset stu_no mov ax, 0b800h mov es, ax mov di, 0 mov ah,17h s: mov al, 0 mov es:[di], al mov es:[di+1], ah inc si add di, 2 loop s mov di, 3840 mov si, offset stu_no mov cx, 74 mov ah, 17h s1: call printgang add di, 2 loop s1 mov di, 3908 mov si, offset stu_no mov cx, len mov ah, 17h s2: call printStu_no inc si add di, 2 loop s2 mov di, 3932 mov si, offset stu_no mov cx, 74 mov ah, 17h s3: call printgang add di, 2 loop s3 mov ax, 4c00h int 21h printStu_no:mov al, [si] mov es:[di], al mov es:[di+1], ah ret printgang:mov al, 45 mov es:[di], al mov es:[di + 1], ah ret code ends end start
task5.asm运行测试截图