实验任务1
给出程序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反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)-14
从CPU的角度,说明是如何计算得到跳转后标号s1其后指令的偏移地址的。
(1)(cx)=(cx)-1
(2)如果(cx)=0,什么也不做,程序继续向下执行;
如果(cx)!=0,则跳转的偏移地址(IP)=(IP)+8位位移量(000D-001B)
回答问题②
② line44,汇编指令 loop s2 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少(位移量数值以十进制数值回答)
-16
从CPU的角度,说明是如何计算得到跳转后标号s2其后指令的偏移地址的。
(1)(cx)=(cx)-1
(2)如果(cx)=0,什么也不做,程序继续向下执行;
如果(cx)!=0,则跳转的偏移地址(IP)=(IP)+8位位移量(0029-0039)
问题③
③ 附上上述分析时,在debug中进行调试观察的反汇编截图
可以看到s1跳转到000D
可以看到s1跳转到0029
实验任务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) =0021 寄存器(bx) = 0026 寄存器(cx) = 076C
② 对源程序进行汇编、链接,得到可执行程序task2.exe。使用debug调试,观察、验证调试结果与理论分析结果是否一致。
实验任务3
给出程序源码task3.asm
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 si,offset x mov cx,len s:mov ah,0 mov al,[si] mov bl,10 div bl;用ax中的数字除以10,商在al中,余数在ah中mov dx,ax call printNumber call printSpace inc si loop s mov ah,4ch int 21h printNumber: mov dx,ax add dx,3030h;数字与字符串之间ascll码值的关系,将数字->字符 mov ah,2;输出字符 int 21h mov ah,2 mov dl,dh int 21h ret printSpace: mov dl,' ' int 21h ret code ends end start
运行测试截图
实验任务4
给出程序源码task4.asm
assume cs:code, ds:data data segment str db 'try',0 len equ $ - str data ends code segment start: mov dh,1 ;设置行数 mov dl,0 ;设置列数 mov cl,2 ;设置颜色 mov ax,data mov ds,ax mov si,0 call show_str mov dh,25 ;重置行列数和颜色 mov dl,0 mov cl,4 call show_str mov ax,4c00h int 21h show_str: push cx push si mov ax,0b800h mov es,ax mov al,0a0h dec dh mul dh mov bx,ax mov al,2 mul dl sub dl,2 add bx,ax ;得到现实的偏移位置 mov di,0 mov ch,0 mov al,cl s: mov cl,ds:[si] jcxz next :判断最后一个字符是否为零,如果是零则结束 mov es:[bx+di],cl ;字符串放到前面 mov es:[bx+di+1],al ;颜色放到后面 add di,2 inc si jmp s next: pop si pop cx ret code ends end start
运行测试截图
实验任务5
给出程序源码task5.asm
assume cs:code, ds:data data segment stu_no db'201983290355' len = $ - stu_no data ends code segment start: mov ax,data mov ds,ax mov di,0 call s mov ah,4ch int 21h s: mov ax,0b800h mov es,ax mov si,1 ;把屏幕24行染成蓝色 mov al,24 mov dl,80 mul dl mov cx,ax s1: mov al,17h mov es:[si],al add si,2 loop s1 sub si,1 ;打印最后一行,计算'-'的个数 mov ax,80 sub ax,len mov dl,2 div dl mov dx,ax ;打印学号左边的‘-’ mov cx,dx call s2 ;打印学号 mov cx,len s3: mov al,ds:[di] mov ah,17h mov word ptr es:[si],ax inc di add si,2 loop s3 mov cx,dx call s2 ret ;打印学号右边的‘-’ s2: mov al,'-' mov ah,17h mov es:[si],ax add si,2 loop s2 ret code ends end start
运行测试截图