实验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
复制代码
问题1:根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,寄存器(ax) = 0021 寄存器(bx) = 0026 寄存器(cx) = 076C
  分析: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调试,观察、验证调试结果与理论分析结果是否一致。

执行到line31前的结果:

 与猜测结果一致。

实验任务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
复制代码
posted @ 2021-12-02 18:15  土鸡老师  阅读(82)  评论(3)    收藏  举报