路过夏天 发表于 2012-7-5 15:09:39

实验九,我的代码

据说比较重要,怕不搞透彻后面课跟不上,因此第一次独立完成实验,特分享我的代码

assume cs:code,ds:data,ss:stack

data segment
db 'welcome to masm!';定义要显示的字符串(共16字节)
db 02h,24h,71h         ;定义三种颜色属性
data ends

stack segment
dw 8 dup(0)
stack ends

code segment
start:

mov ax,data
mov ds,ax
mov ax,stack
mov ss,ax
mov sp,10h


mov ax,0b872h          ;算出屏幕第12行中间的显存的段起始位置放入ax中
mov es,ax            ;此时es为屏幕第12行中间的显存的段起始位置
mov bx,0               ;bx索引源字符串数据的偏移地址
mov bp,0               ;bp索引要写入的显存偏移地址
mov si,10h             ;si索引颜色属性源数据的偏移地址

mov cx,3               ;外部循环三次,每次循环写入一行完整的字符串及属性
s0:                  
push cx                ;将当前外循环计数推入栈保护起来
mov bx,0               ;bx索引源字符串数据的偏移地址,内循环结束出来后重新清零,为下一行从第一个字符串开始取值做准备
mov di,bp            ;bp保存的当前行第一个字符"w"写入的显存偏移地址,放入di保护

mov cx,10h             ;内循环16次,每次循环写入一个字符及属性
s:
mov al,ds:         ;
mov es:,al         ;将当前行第一个字符写入指定段的第1个显存偏移地址
mov al,ds:         ;
mov es:,al       ;将当前行第一个字符属性写入指定段的第2个显存偏移地址
add bx,1               ;每次内循环源字符串寻址地址递增1个字节,指向下一个字符
add bp,2               ;字符和属性占2个字节,每次内循环写入显存偏移地址递增2个字节
loop s

mov bp,di            ;内循环结束出来,重新恢复bp为当前显示行第一个字符"w"的偏移地址
add bp,0a0h            ;内循环结束出来,要写入的目的显存偏移地址增加160个字节,索引到下一行"w"要写入显存的偏移地址
add si,1               ;内循环结束出来,颜色数据索引偏移地址递增1个字节,指向下一行的颜色属性
pop cx               ;内循环结束出来,重新恢复外循环的计数,确保下一个外循环正常运行
loop s0

mov ax,4c00h
int 21h
code ends
end start

路过夏天 发表于 2012-7-5 15:18:47

这个实验刚才看到有人按列循环,一个循环就可以了
不过毕竟亲自用了嵌套循环,获得这样的经验也是很值的

三田学校 发表于 2012-7-24 11:12:12

本帖最后由 三田学校 于 2012-7-24 15:04 编辑

assume cs:code,ds:data
data segment
db 'welcome to masm!';定义要显示的字符串(共16字节)
db 02h,24h,71h         ;定义三种颜色属性
data ends
code segment
start:
mov ax,data
mov ds,ax

mov ax,0b872h
mov es,ax

mov bx,0
mov di,0
mov cx,10h

s0:
mov al,
mov es:,al
mov es:0a0h,al
mov es:140h,al

mov al,ds:
mov es:1,al
mov al,ds:
mov es:0a1h,al
mov al,ds:
mov es:141h,al
inc bx
add di,2
loop s0

mov ax,4c00h
int 21h
code ends
end start


一个循环实现,简单明了。
页: [1]
查看完整版本: 实验九,我的代码