|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 kiven 于 2011-12-5 15:37 编辑
;----------------------实验十(1)-显示字符串------------自写-----------------------
assume cs:code,ds:data,ss:stack
data segment
db 'happy new year ! we must be happy ! ',0
data ends
stack segment
db 16 dup (0)
stack ends
code segment
main: ;显存在址的范围是B8000-BFFFF
mov dh,8 ;dh=行号(取值范围是0-24)
mov dl,3 ;dl=列号(取值范围是0-79)
mov cl,5 ;cl=颜色,ds:si指向字符串的首地址
mov ax,data
mov ds,ax
mov ax,stack
mov ss,ax
mov sp,10h
mov si,0
mov di,0
mov bx,0
mov ax,0b800h ;把显存的段地址放入ES中
mov es,ax
call show_str ;调用显示字符的函数
mov ax,4c00h
int 21h
show_str:
mov al,0a0h
mul dh
push ax ;行的偏移地址
mov al,2 ;-------这个地方,本来是想用栈来解决的,可是这用栈了,那么以后的CX怎么弄求帮助
mul dl
push ax ;列的偏移地址
pop ax ;取出列的地址放入BX中
add bx,ax
pop ax
add bx,ax ;取出行的地址加入BX中
move:
mov al,ds:[si] ;把字符放入al中
mov ah,5 ;把字符属性放入ah中
mov es:[bx],ax ;把字符各字符属性放入显存中指字的位置
mov ch,0
mov cl,ds:[si] ;用CX为了判断字符是不是到头
inc si ;指向下一个字符
add bx,2 ;指向显存中的下一个地址
jcxz ok ;如果cx为0 跳到指定的标号处
jmp move ;循环存放
ok: ret ;程序返回
code ends
end main
|
|