whiteblossoms

导航

实验3 转移指令跳转原理及其简单应用编程

实验任务1

使用任何一款文本编辑器,录入8086汇编程序源码task1.asm。
task1.asm

assume cs:code, ds:data
data segment
x db 1, 9, 3
len1 equ $ - x ; 符号常量, $指下一个数据项的偏移地址,这个示例中,是3
y dw 1, 9, 3
len2 equ $ - y ; 符号常量, $指下一个数据项的偏移地址,这个示例中,是9
data ends
code segment
start:
mov ax, data
mov ds, ax
mov si, offset x ; 取符号x对应的偏移地址0 -> si
mov cx, len1 ; 从符号x开始的连续字节数据项个数 -> cx
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 ; 取符号y对应的偏移地址3 -> si
mov cx, len2/2 ; 从符号y开始的连续字数据项个数 -> cx
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

对源程序进行汇编、链接,得到可执行程序task1.exe,运行后,结合运行结果和注释,及必要的debug
调试:
1、理解运算符offset、伪指令equ、预定义符号$的灵活使用。
通过line5、line8,以及数据项的数据属性(字节、字、双字,等),可以方便计算出连续数据项
的个数,而无需人工计数。
注*: 符号常量len1, len2不占用数据段内存空间
2、回答问题
① line27, 汇编指令 loop s1 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,
分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得
到跳转后标号s1其后指令的偏移地址的。

偏移量为标号地址减去跳转后第一条指令的地址 13-27-14 位移为8位,且用补码表示,F2二进制为11110010,原码即10001110确为-14

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

同①,F0二进制为11110000,对应原码为10010000,十进制表示为-16 亦可通过计算0029h-0039h

③ 附上上述分析时,在debug中进行调试观察的反汇编截图

实验任务2

使用任何一款文本编辑器,录入8086汇编程序源码task2.asm。
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

① 根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,寄存器(ax) = ? 寄存器
(bx) = ? 寄存器(cx) = ?

根据call指令把下一个指令的地址压入栈中可得 ax应为offset s1 bx=offset s2 cx=cs

② 对源程序进行汇编、链接,得到可执行程序task2.exe。使用debug调试,观察、验证调试结果与理论
分析结果是否一致。

由上图可知AX BX CX的值符合分析结果

实验任务3

代码:

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 cx,7
	mov byte ptr ds:[len],10
	mov bx,0
	s:
	mov al,ds:[bx]
	mov ah,0
	call printNumber
	call printSpace
	inc bx
	loop s
	mov ah,4ch
	int 21h
	
printNumber:
	div byte ptr ds:[len]
	mov dx,ax
	or dl,30h
	mov ah,2
	int 21h
	mov dl,dh
	mov ah,2
	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 bh,0
	mov bl,00000100B
	mov si,0
	call printStr
	
	mov bl,00000100B
	mov bh,24
	mov si,0
	mov cx,len
	call printStr

	mov ah,4ch
	int 21h

printStr:
	mov ax,0b800h;
	mov es,ax
	mov dx,160
	mov ax,0
	mov al,bh
	mul dx
	mov di,ax	

s:
	mov al,ds:[si]
	mov es:[di],al
	inc si
	inc di
	mov es:[di],bl
	inc di
	loop s	
	ret

	
code ends
end start

结果:

实验任务5

代码:

assume cs:code,ds:data
data segment
	stu_no db '201983290261'
	len = $ - stu_no
data ends

code segment
start:
	mov ax,data
	mov ds,ax
	mov bl,00010111B
	mov ax,0b800h
	mov es,ax
	mov ax,25
	mov dx,80
	mul dl
	mov cx,ax
	mov di,0
	mov al,32
s:
	mov es:[di],al
	inc di
	mov es:[di],bl
	inc di
	loop s
	
	
	
	mov ax,24
	mov dx,160
	mul dx
	mov cx,34
	mov di,ax
	mov ax,45
s1:
	mov es:[di],ax
	mov es:[di+1],bl
	add di,2
	loop s1

	mov cx,len
	mov si,0
s2:
	mov al,ds:[si]
	mov es:[di],al
	mov es:[di+1],bl
	add di,2
	inc si
	loop s2
	
	mov ax,45
	mov cx,34
s3:
	mov es:[di],ax
	mov es:[di+1],bl
	add di,2
	loop s3

	mov ah,4ch
	int 21h
code ends
end start

结果:

posted on 2021-11-30 15:31  whiteblossoms  阅读(89)  评论(3编辑  收藏  举报