|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
补全程序,利用loop指令,实现在内存2000H段中查找第一个值为0的字节,找到后,将它的偏移地址存储在dx中。
assume cs:code
code segment
start: mov ax,2000h
mov ds,ax
mov bx,0
s: mov cl,[bx] //////////////////////////
mov ch,0 //////////////////////////
inc cx //////////////////////////这块cx加1,那这个程序岂不是要一直循环么?求大佬解释斜杠标注处指令!!!
inc bx /////////////////////////////
loop s
ok: dec bx
mov dx,bx
mov ax,4c00h
int 21h
code ends
end start
本帖最后由 兰陵月 于 2017-11-10 22:09 编辑
s: mov cl,[bx] //////////////////////////
假如这里取到了“0”,那CL就等于“0”
mov ch,0 //////////////////////////
把ch也置0,这样CX就变成了0
inc cx //////////////////////////这块cx加1,那这个程序岂不是要一直循环么?求大佬解释斜杠标注处指令!!!
执行完之后,CX=1
inc bx ////////////////////////////
这句不解释了
loop s
执行这句的时候,先将CX-1,然后检查CX是否为0,如果为0,循环跳出,如果不为0,循环继续。这是loop指令的解释
因为上面执行完“inc cx”后,CX=1,所以执行这里时,CX-1=0,loop循环因此结束。
假如在mov cl,[bx]取到的不是“0”,则循环不会结束。你可以推断一下。
只有取到了“0”或者碰到字符串的0结束标志,循环才会终止。
|
|