1、 掌握转移指令的原理分析。
2、不同转移指令之间的转换及其灵活应用。
1、 依据位移进行转移的转移指令的灵活运用。
2、 转移指令的原理分析及调试追踪。
编程实现在屏幕中间分别显示绿色、绿底红色、白底蓝色的字符串‘welcome to masm!’
8025彩色字符模式显示缓冲区(以下简称为显示缓冲区)的结构:内存地址空间中,B800H ~ BFFFH共32KB的空间,为8025彩色字符模式的显示缓冲区。向这个地址空间写入数据,写入的内容将立即出现在显示器上。在8025彩色模式下,显示器可以显示25行,每行80个字符,每个字符可以有256种属性(背景色、前景色、闪烁、高亮等组合信息)。这样一个字符在显示缓冲区就要占两个字节,分别存放字符的ASCII码和属性。8025模式下,一屏的内容在显示缓冲区中共占4000个字节。显示缓冲区分为8页,每页4KB,显示器可以显示任意一页的内容。一般情况下,显示第0页的内容。也就是说通常情况下,B800H~B8F9FH中的4000个字节的内容将出现在显示器上。
在一页显示缓冲区中:
偏移000~09F对应显示器上的第1行(80个字符占160个字节);
偏移0A0~13F对应显示器上的第2行;
偏移140~1DF对应显示器上的第3行;
以此类推,可知偏移F00~F9F对应显示器上的第25行.
在一行中,一个字符占两个字节的存储空间(一个字),低位字节存储字符的ASCII码,高位字节存储字符的属性。一行共80个字符,160个字节。
即在第一行中:
00~01单元对应显示器上的第1列;
02~03单元对应显示器上的第2列;
04~05单元对应显示器上的第3列;
以此类推可知,9E~9F单元对应显示器上的第80列。
例:在显示器的0行0列显示黑底绿色的字符串‘ABCDEF’
(‘A’的ASCII码为41H,02H表示黑底绿色)
显示缓冲区里的内容为:
00 01 02 03 04 05 06 07 08 09 0A 0B….0E 0F
B800:0000 41 02 42 02 43 02 44 02 45 02 46 02………………
:
B800:00A0 … … … … … … … … … … … … … … …
可以看出,在显示缓冲区中,偶地址存放字符,奇地址存放字符的颜色属性。
一个在屏幕上显示的字符,具有前景色(字符色)和背景色(底色)两种颜色,字符还可以以高亮度和闪烁的方式显示。前景色、背景色、闪烁、高亮等信息被记录在属性字节中。
属性字节的格式:
7 6 5 4 3 2 1 0
含义 BL R G B I R G B
闪烁 背景 高亮 前景
R: 红色
G: 绿色
B: 蓝色
可以按位位置设置属性字节,从而配出各种不同的前景色和背景色。
比如:
红底绿字,属性字节为:01000010B;
红底闪烁绿字,属性字节为:11000010B;
红底高亮绿字,属性字节为:01001010B;
黑底白字,属性字节为:00000111B;
白底蓝字,属性字节为:01110001B。
例:在显示器的0行0列显示红底高亮闪烁绿色的字符串‘ABCDEF’
(红底高亮闪烁绿色,属性字节为:11001010B,CAH)
显示缓冲区里的内容为:
00 01 02 03 04 05 06 07 08 09 0A 0B….0E 0F
B800:0000 41 CA 42 CA 43 CA 44 CA 45 CA 46 CA………………
:
B800:00A0 … … … … … … … … … … … … … … …
注意:闪烁的效果必须在全屏DOS方式下才能看到。
编程:
assume cs:code, ds:data, ss:stack
data segmentdb ‘welcome to masm!’db 02h, 24h,71h
data endsstack segment db 16 dup (0)
stack endscode segment
start: code ends
end start
完成代码编写,并上机调试,追踪运行结果。
2. 采用函数调用方法编程实现在屏幕的8行3列, 用绿色显示data段中的字符串,其中(dh)=行号(取值范围0~24),(dl)=列号(取值范围0 ~79),(cl)=颜色,ds:si指向字符串的首地址。
代码:
assume cs:code
data segmentdb ‘welcome to masm!’,0
data endscode segment
start: mov dh,8mov dl,3mov cl,2mov ax,datamov ds,axmov si,0call show_strmov ax,4c00hshow_str:code ends
end start
(1)完整代码:
assume cs:codesg, ds:datasg, ss:stacksg
datasg segmentdb 'welcome to masm!' db 02H, 024H, 71H, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 dw 12*160+64, 13*160+64, 14*160+64, 0, 0, 0, 0, 0
datasg ends
stacksg segment dw 0,0,0,0,0,0,0,0
stacksg ends
codesg segment
start:mov ax, stacksg mov ss, ax mov sp, 16mov ax, datasg mov ds, axmov ax, 0B800H mov es, axmov cx, 3 mov bx, 16 mov di, 32 s0: push cx mov cx, 16 mov bp, [di] mov si, 0s1: mov al, [si] mov ah, [bx] mov es:[bp], axinc bpinc bp inc si loop s1pop cxadd bx, 1 add di, 2 loop s0mov ax,4c00Hint 21H
codesg ends
end start
运行结果:
(2)完整代码
assume cs:code
data segment
db 'welcome to masm!',0
data ends
code segmentstart:mov dh,8mov dl,3mov cl,2mov ax,datamov ds,axmov si,0call show_strmov ax,4c00hint 21hshow_str:push dxpush cxpush dspush si mov ax,0b800hmov es,ax mov ax,0a0hmul dhmov bx,ax mov ax,2mul dlmov di,ax mov al,cl mov ch,0set:mov cl,[si]jcxz ok mov es:[bx+di],cl mov es:[bx+di+1],al inc siadd di,2jmp short setok:pop sipop dspop cxpop dxret
code ends
end start
结果:
1、 通过此次试验,总结寄存器的作用,灵活利用各个寄存器。ds:数据段、cs:代码段、ss:栈段,ip:代码段偏移; sp:栈段偏移,bx, si, di, bp 寻址变量 ,cx: 循环变量。
2、 DOS环境下,一共35行,题目要求在最中间位置,通过计算应该是在12行、13行、14行来显示字符串,目标字符串总共16个字符:字母,空格和标点符号。每列显示80个字符,中间显示,我们从每行第32个字符开始显示内容,即第64个字节处开始显示。 计算显示字符的位置为:
; 12160+64 = 1984 => 07C0H
; 13160+64 = 2144 => 0860H
; 14*160+64 =2304 => 0900H
3、 寄存器:
cx作为行显示3行的行循环和移动字符列循环。es:写入的段寄存器。bx:颜色在数据段的索引。di:每行开始位置在数据段的索引。si:字符在数据段的索引。bp:每个字符具体的显示位置。al:存储字符的ASCII码。ah:存储字符的属性。
本文发布于:2024-01-29 18:00:45,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170652244917274.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |