实验3 转移指令跳转原理及其简单应用编程
实验3 转移指令跳转原理及其简单应用编程
实验任务1:
task1.asm源码:
1 assume cs:code, ds:data 2 3 data segment 4 x db 1, 9, 3 5 len1 equ $ - x 6 7 y dw 1, 9, 3 8 len2 equ $ - y 9 data ends 10 11 code segment 12 start: 13 mov ax, data 14 mov ds, ax 15 16 mov si, offset x 17 mov cx, len1 18 mov ah, 2 19 s1:mov dl, [si] 20 or dl, 30h 21 int 21h 22 23 mov dl, ' ' 24 int 21h 25 26 inc si 27 loop s1 28 29 mov ah, 2 30 mov dl, 0ah 31 int 21h 32 33 mov si, offset y 34 mov cx, len2/2 35 mov ah, 2 36 s2:mov dx, [si] 37 or dl, 30h 38 int 21h 39 40 mov dl, ' ' 41 int 21h 42 43 add si, 2 44 loop s2 45 46 mov ah, 4ch 47 int 21h 48 code ends 49 end start
运行结果截图:

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

答:机器码为E2F2,F2即为跳转的位移量的补码,进行求补后得出10001110,十进制数对应-14,因此跳转的位移量是-14。
从CPU的角度,当cx不为0时,(IP)=(IP)+8位位移,而此时IP地址更新为Loop指令的后一条指令的地址001B。因此位移量为-14时,从001B跳转到000D。
② line44,汇编指令 loop s2 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s2其后指令的偏移地址的。

答:机器码为E2F0,F0即为跳转的位移量的补码,进行求补后得出10010000,十进制数对应-16,因此跳转的位移量是-16。
or dl, 30h命令占三个字节,其他指令各占两个字节,加起来一共16字节。
实验任务2:
task2.asm源码:
1 assume cs:code, ds:data 2 3 data segment 4 dw 200h, 0h, 230h, 0h 5 data ends 6 7 stack segment 8 db 16 dup(0) 9 stack ends 10 11 code segment 12 start: 13 mov ax, data 14 mov ds, ax 15 16 mov word ptr ds:[0], offset s1 17 mov word ptr ds:[2], offset s2 18 mov ds:[4], cs 19 20 mov ax, stack 21 mov ss, ax 22 mov sp, 16 23 24 call word ptr ds:[0] 25 s1: pop ax 26 27 call dword ptr ds:[2] 28 s2: pop bx 29 pop cx 30 31 mov ah, 4ch 32 int 21h 33 code ends 34 end start
分析:ds:[0]中存放的是s1的偏移地址,ds:[2]中存放的是s2的偏移地址。
因此第一个call将下一条指令的偏移地址0021压入栈,再跳转到s1处执行pop ax,将0021出栈存入ax。
第二个call将下一条指令的段地址076C和偏移地址0026压入栈,再跳转到s2处执行pop bx,将0026出战存入bx,将076C出栈存入cx。
问题2:对源程序进行汇编、链接,得到可执行程序task2.exe。使用debug调试,观察、验证调试结果与理论分析结果是否一致。

与猜测结果一致。
实验任务3:
task3.asm源码编写:
1 assume ds:data, cs:code 2 data segment 3 x db 99, 72, 85, 63, 89, 97, 55 4 len equ $- x 5 data ends 6 7 code segment 8 start: 9 mov ax, data 10 mov ds, ax 11 mov si, offset x 12 mov cx, len 13 mov byte ptr ds:[10], 10 14 15 s1: mov ah, 0 16 mov al, ds:[si] 17 18 div byte ptr ds:[10] 19 call printNumber 20 call printSpace 21 inc si 22 loop s1 23 24 mov ax, 4c00h 25 int 21h 26 27 printNumber:mov bx, ax 28 or bl, 30h 29 or bh, 30h 30 mov ah, 2 31 mov dl, bl 32 int 21h 33 mov dl, bh 34 int 21h 35 ret 36 37 printSpace:mov ah, 2 38 mov dl, ' ' 39 int 21h 40 ret 41 42 code ends 43 end start
结果截图:

实验任务4:
task4.asm源码编写:
1 assume cs:code, ds:data 2 3 data segment 4 str db 'try' 5 len = $-str 6 data ends 7 8 stack segment 9 db 16 dup(0) 10 stack ends 11 12 code segment 13 start: 14 mov ax,data 15 mov ds,ax 16 mov ax,stack 17 mov ss,ax 18 mov sp,16 19 20 mov si,offset str 21 mov cx,len 22 mov bl,2;绿色 23 mov bh,0 24 call printStr 25 26 mov si,offset str 27 mov cx,len 28 mov bl,4 29 mov bh,24 30 call printStr 31 32 mov ah,4ch 33 int 21h 34 35 printStr: 36 mov dx,0b800h 37 mov es,dx 38 mov ah,0 39 mov al,bh 40 mov di,160 41 mul di 42 mov di,ax 43 s: mov al,ds:[si] 44 mov es:[di],al 45 inc di 46 mov es:[di],bl 47 inc di 48 inc si 49 loop s 50 ret 51 52 code ends 53 end start
结果截图:

实验任务5:
task5.asm源码编写:
1 assume ds:data, cs:code 2 data segment 3 stu_no db '201983290434' 4 len = $ - stu_no 5 data ends 6 7 code segment 8 start: 9 mov ax, data 10 mov ds, ax 11 mov cx, 4000 12 mov si, offset stu_no 13 mov ax, 0b800h 14 mov es, ax 15 mov di, 0 16 mov ah,17h 17 18 s: mov al, 0 19 mov es:[di], al 20 mov es:[di+1], ah 21 inc si 22 add di, 2 23 loop s 24 25 mov di, 3840 26 mov si, offset stu_no 27 mov cx, 74 28 mov ah, 17h 29 s1: call printgang 30 add di, 2 31 loop s1 32 33 mov di, 3908 34 mov si, offset stu_no 35 mov cx, len 36 mov ah, 17h 37 s2: call printStu_no 38 inc si 39 add di, 2 40 loop s2 41 42 mov di, 3932 43 mov si, offset stu_no 44 mov cx, 74 45 mov ah, 17h 46 s3: call printgang 47 add di, 2 48 loop s3 49 50 mov ax, 4c00h 51 int 21h 52 53 printStu_no:mov al, [si] 54 mov es:[di], al 55 mov es:[di+1], ah 56 ret 57 58 printgang:mov al, 45 59 mov es:[di], al 60 mov es:[di + 1], ah 61 ret 62 63 code ends 64 end start


浙公网安备 33010602011771号