在汇编语言中,jcxz 标号 指令是一个有条件转移指令,用于检测CX寄存器的值,如果CX寄存器的值为0,则跳转到指令中标号所指定的地址处执行;否则,指令将继续顺序执行。
1. jcxz 标号
(1)(cx) = 0,转移到标号处执行;
(2)(cx) != 0,什么都不做,程序指令继续往下顺序执行;
(3)jcxz 标号 是短转移指令,对应的机器码包含8位转移位移,用补码形式表示,所以对应的IP(偏移地址)修改范围相对于当前IP来说,范围在:-128 ~ 127,即:(IP) = (IP) + 8位位移。
其功能就像 C 语言所描述的代码:if ((cx) == 0 ) jmp short 标号;
示例:利用 jcxz 指令,实现从CS(段地址)中查找第一个值为0的字节,并把偏移地址存储在dx寄存器中
assume cs:code
code segment
start:
mov ax, cs
mov ds, ax
mov bx, 0
s: mov cx, 0 ;重置cx
mov cl, [bx] ;cl = ds:[bx]指向的内存单元中的值
jcxz ok ;cx = 0,则跳转到标号ok处执行指令,否则该指令什么都不做,CPU继续顺序执行下一条指令
inc bx
jmp short s ;jmp无条件转移的短转移指令,跳转到标号s处执行指令
ok: mov dx, bx
mov ax, 4c00h
int 21h
code ends
end start
从图中,我们可知,程序加载到内存后
(1)-r 查看各个寄存器设置情况,CS:IP = 204D:0000
(2)-d cs:0 查看128个字节的内存中,偏移地址 = 5,是第一个值为 0 的字节
(3)-u 查看汇编指令以及其对应的机器码
(4)-g 0013 控制CPU从CS:IP指向的指令处开始执行指令,直到 IP = 0013时停下来,这时 dx = 0005,和我们在步骤(2)中观察到的第一个值为 0 的字节的偏移地址 = 5 是一致的
(5)jcxz ok 被编译器编译成 jcxz 0011,其对应的机器指令为:E303(低字节序),低8位:E3是操作码,高8位:03是转移位移,转移位移 = 0011h - 000Eh = 03h。
参考文献
《汇编语言(第4版)》王爽