涉及到三个寄存器:ECX, AL, EDI 和标志寄存器的ZF位和DF位.
REPNE 先检查ECX是否为0, 不为0则循环.
SCASB 相当于 SCAS BYTE PTR DS:[EDI] 即 SUB AL, BYTE PTR DS:[EDI]. 且, 如果标志寄存器DF=0, 则执行SCASB后, EDI = EDI + 1字节; 如果DF=1, 则EDI = EDI - 1字节;
查过的说明是: 当ECX==0或者ZF==1的时候终止循环. 但在OD里手动设置ZF=1后, 循环并未停止, 什么原因? 在OD里观察, 似乎跟ZF没什么关系, 但是SCASB 相当于 SUB AL, BYTE PTR DS:[EDI], 如果两值相等, 那么ZF一定等于1才对.
char *str = "1234567890";
__asm
{
mov al, ‘7‘
mov edi, str
mov ecx, -1
repnz scasb
not ecx
dec ecx
}
时间: 2025-01-04 13:28:30