转移指令的原理 实验9 显存什么都不输出?
代码不报错 个地方都没事 是cmd的问题吗 小甲鱼的代码也一样什么都不显示 求解如下 只是甲鱼的代码也不行
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
xor bx,bx ;bx清零,用来索引颜色
mov ax,0b872h ;算出屏幕第12行中间的显存的段起始位置放入ax中
mov cx,3 ;S3循环控制行数,外循环为3次,因为要显示三个字符串
s3: push cx ;三个进栈操作为外循环s3保存相关寄存器的值
push ax ;以防止它们的值在内循环中被破坏
push bx
mov es,ax ;此时es为屏幕第12行中间的显存的段起始位置
mov si,0 ;si用来索引代码列的字符
mov di,0 ;di用来定位目标列
mov cx,10h ;S1循环控制存放的字符,内循环为10h次,因为一个字符串中含10h个字节
s1: mov al,ds:
mov es:,al
inc si
add di,2
loop s1 ;此循环实现偶地址中存放字符
mov di,1 ;di的值设为1,从而为在显存奇地址中存放字符的颜色属性做准备
pop bx
mov al,ds:10h ;取颜色属性
inc bx
mov cx,10h ;第二个内循环也为10h次
s2: mov es:,al
add di,2
loop s2 ;此循环实现奇地址中存放字符的颜色属性
;以下4句为下一趟外循环做准备
pop ax
add ax,0ah ;将显存的段起始地址设为当前行的下一行
;[在段地址中加0ah,相当于在偏移地址中加了0a0h(=160d)]
pop cx
loop s3
mov ax,4c00h
int 21h
code ends
end start
可能是cmd的bug
需要先运行一下debug
看图
人造人 发表于 2017-1-28 19:06
可能是cmd的bug
需要先运行一下debug
还是不行
achang1212 发表于 2017-1-28 19:12
还是不行
这样试试
人造人 发表于 2017-1-28 19:21
这样试试
是啊我感觉 效果应该出来了就是在瞬间又关闭了我用debug调试就 可以运行exe就看不见效果 achang1212 发表于 2017-1-28 19:30
是啊我感觉 效果应该出来了就是在瞬间又关闭了我用debug调试就 可以运行exe就看不见效果
在 int 21H 执行后 就自动关闭了 所以看不见效果 人造人 发表于 2017-1-28 19:21
这样试试
出来了 ! 微笑 achang1212 发表于 2017-1-28 19:36
出来了 ! 微笑
问题解决了?
人造人 发表于 2017-1-28 19:42
问题解决了?
恩啊 achang1212 发表于 2017-1-28 19:46
恩啊
哦 人造人 发表于 2017-1-28 19:21
这样试试
我也遇到这个问题,是cmd bug? xusiman 发表于 2017-2-12 00:18
我也遇到这个问题,是cmd bug?
也许吧,我没有在dos实模式下试^_^ 人造人 发表于 2017-1-28 19:21
这样试试
这个g命令输入,回车没反应是什么情况?了解吗?
页:
[1]