鱼C论坛

 找回密码
 立即注册
查看: 3303|回复: 2

[技术交流] 实验9完成了,分享下

[复制链接]
发表于 2011-6-9 15:22:34 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 liuhui88126 于 2011-6-9 15:26 编辑

assume cs:code
a segment ;定义数据
db 'welcome to masm!'       ;0-15位要显示的字母 16-18位字体颜色与背景色
db 2h,24h,71h
a ends
b segment
db 0                                    ;做个一栈,有用的。因为用到内循环
b ends
code segment
start:    mov ax,a
            mov es,ax
            mov si,0
            mov di,0                  ;不解释。

            mov ax,0b800h
            mov ds,ax
            mov bx,0                 ;不解释
            mov ax,b
            mov ss,ax
            mov sp,0
            mov cx,3
      s1:  push cx           ;把cx放入栈,以免与下面一个循环搞混,大家可以试试看把进出栈去掉的效果,也不错哦。O(∩_∩)O哈哈~
            mov cx,16
       s:  mov al,es:[si]              ;把当前偏移地址中的数据放入al
            mov ah,es:16[di]            ;再把字母颜色与背景色的数据放入ah中,注:因为高位地址存放的是颜色属性,地位地址存放的是字 母,2个都是8位的,所以直接用一个16的寄存器存放,方便很多。


            mov ds:7c0h[bx],ax        ;再把存放好的字母与颜色属性放入要写出的地址中。 注:一行80个字符  1个字母=2个字节,所以1行就是160个字节,一共25行,所以从12行开始写出,就是12*160=1920=780H,而且是要从中间输出,因为一行字母是16个字符,我们把它切分一下就可以了,(80-16)/2=32个字符=64个字节=40h  780h+40h=7c0h,,所以从中间输出的话,偏移地址就是7c0h了

             inc si                        ;接着下一个字母
             add bx,2h                ;因为一次性是输入2个字节,所以bx+2
             loop s                       ;不解释
             add bx,80h              ; 接着下一行。 一行160个字节减去显示数据的32个字节就可以了
             mov si,0                   ;si初始化
             inc d i                       ;接着下一个颜色属性
             pop cx                     ;不解释
             loop s1

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

;大家可以试试看把进出栈去掉的效果,也不错哦。O(∩_∩)O哈哈~

点评

有源代码为什么不用代码框了?  发表于 2011-6-9 18:21
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2011-6-9 15:49:58 | 显示全部楼层
我就看看。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2011-6-9 19:50:14 | 显示全部楼层
我也学习下
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-11 19:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表