实验内容、程序清单及运行结果
显示字符串:
问题:
显示字符串是现实工作中经常要用到的功能,应该编写一个通用的子程序来实现这个功能。我们应该提供灵活的调用接口,使调用者可以决定显示的位置(行、列)、内容和颜色。
提示
(1) 子程序的入口参数是屏幕上的行号和列号,注意在子程序内部要将它们转化为显存中的地址,首先要分析一下屏幕上的行列位置和显存地址的对应关系:
(2) 注意保存子程序中用到的相关寄存器:
(3) 这个子程序的内部处理和显存的结构密切相关,但是向外提供了与显存结构无关的接口。通过调用这个子程序,进行字符串的显示时可以不必了解显存的结构,为编程提供了方便。在实验中,注意体会这种设计思想。
子程序描述
名称:show_str
功能:在指定的位置,用指定的颜色,显示一个用0结束的字符串。
参数:(dh)=行号(取值范围0~24),(dl)=列号(取值范围0~79),
(cl)=颜色,ds:si指向字符串的首地址
本例程序代码如下:
assume cs:code
data segment
db 'Welcome to masm !',0
data ends
code segment
start:
mov dh,8;行
mov dl,3;列
mov cl,2;颜色
mov ax,data
mov ds,ax
mov si,0
call show_str
mov ax,4c00h
int 21h
show_str:
mov bl,cl
mov ax,0b800h
mov es,ax
sub di,di
dec dh
dec dl
;计算显示位置
mov al,160
mul dh
add dl,dl
mov cl,dl
mov ch,0
add ax,cx;行加列
mov di,ax
s: mov cl,ds:[si]
mov ch,0
jcxz ok;判断是否为零
;输出
mov ax,ds:[si]
mov es:[di],ax
inc di
inc si
mov es:[di],bl
inc di
jmp short s
ok: ret
code ends
end start
思路:
先计算行和列的字节数,然后加起来,累加在0b800h后面,即得显示初始位置,然后通过jcxz来判断字符串结尾进行数据传输循环
程序执行截图:
修改相关数据后:
- 解决除法溢出的问题