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

一、实验目的
1. 理解和掌握转移指令的跳转原理
2. 掌握使用call和ret指令实现子程序的方法,理解和掌握其参数传递方式
3. 理解和掌握80×25彩色字符模式显示原理
4. 综合应用寻址方式和汇编指令完成简单应用编程

 

二、实验准备
复习教材9-10章:
转移指令的跳转原理
汇编指令jmp, loop, jcxz, call, ret, retf的用法

 

三、实验内容

1. 实验任务1

使用任何一款文本编辑器,录入8086汇编程序源码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
① line27, 汇编指令 loop s1 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s1其后指令的偏移地址的。
 line27 loop命令的机器码为E2F2,F2的八位二进制形式为11110010,其补码为10001110,十进制形式为-14,即位移量为14
② line44,汇编指令 loop s2 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s2其后指令的偏移地址的。
line44 loop命令的机器码为E2F0,F0的八位二进制形式为11110000,补码为10010000,十进制形式为-16,即位移量为16
③ 附上上述分析时,在debug中进行调试观察的反汇编截图

2. 实验任务2
使用任何一款文本编辑器,录入8086汇编程序源码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
① 根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,寄存器(ax) = ? 寄存器(bx) = ? 寄存器(cx) = ?
ax=0021,bx=0026,cx=076C
② 对源程序进行汇编、链接,得到可执行程序task2.exe。使用debug调试,观察、验证调试结果与理论分析结果是否一致。
一致

 

3. 实验任务3
针对8086CPU,已知逻辑段定义如下:
编写8086汇编源程序task3.asm,在屏幕上以十进制形式输出data段中这一组连续的数据,数据和数据之间以空格间隔。
要求:
编写子程序printNumber
功能:以十进制形式输出一个两位数
入口参数:寄存器ax(待输出的数据 --> ax)
出口参数:无
编写子程序printSpace
功能:打印一个空格
入口参数:无
出口参数:无
在主体代码中,综合应用寻址方式和循环,调用printNumber和printSpace, 实现题目要求。
代码:
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
针对8086CPU,已知逻辑段定义如下:
编写8086汇编源程序task4.asm,在屏幕上以指定颜色、指定行,在屏幕上输出字符串。
要求:
编写子程序printStr
功能:在指定行、以指定颜色,在屏幕上显示字符串
代码:
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 si,offset str
   mov bh,0
   mov bl,2
   call printStr
   
   mov cx,len
   mov si,offset str
   mov bh,24
   mov bl,4
   call printStr
   
   mov ah,4ch
   int 21h
printStr:
   ;计算行对应段地址
   mov al,0ah
   mul bh
   add ax,0b800h
   mov es,ax

   mov di,si
   ;写入显存
s: mov al,ds:[si]
   mov ah,bl
   mov es:[di],ax
   inc si
   add di,2
   loop s
   ret
code ends
end start
正确编写后,预期测试结果如下:
实现不了绿色的try

 

 

 
5. 实验任务5
针对8086CPU,针对8086CPU,已知逻辑段定义如下:
在80×25彩色字符模式下,在屏幕最后一行正中间显示学号。要求输出窗口蓝底,学号和两侧折线,以
白色前景色显示。
注*:
1. 80×25彩色字符模式显示缓冲区结构,参见教材「实验9 根据材料编程」里的说明。
2. 编写程序实现时,将data段的学号换成自己的学号。
程序正确编写后,预期输出效果如下:
代码:
assume cs:code, ds:data

data segment
    stu_no db '201983290305' 
    len = $ - stu_no 
data ends

code segment
start:
    mov ax, data
    mov ds, ax
    mov di, 0

    call printStuNum
    
    mov ah, 4ch
    int 21h

printStuNum:
    mov ax, 0b800h
    mov es, ax
    mov si, 1

    mov al, 24
    mov dl, 80
    mul dl
    
    mov cx, ax
    printBlue:
        mov al, 17h    ;00010111
        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 printheng

    mov cx, len
    printStu:    ;输出学号
        mov al, ds:[di]
        mov ah, 17h
        mov word ptr es:[si], ax
        inc di
        add si, 2
    loop printStu

    mov cx, dx
    call printheng

    ret
    
printheng:
    mov al, '-'
    mov ah, 17h
    mov word ptr es:[si], ax
    add si, 2
    loop printheng
    ret
     
code ends
end start

 

posted @ 2021-11-28 12:02  余昕璇  阅读(108)  评论(3编辑  收藏  举报