Я сделаю здесь более широкий ответ.
Вообще говоря, в x86 есть два типа условных переходов:
Арифметические прыжки - например, JZ (прыжок, если ноль), JC (прыжок, если перенос), JNC (прыжок, если не перенос) и т. Д.
Сравнительные прыжки - JE (прыжок, если равен), JB (прыжок, если ниже), JAE (прыжок, если выше или равный) и т. Д.
Итак, используйте первый тип только после арифметических или логических инструкций:
sub eax, ebx
jnz .result_is_not_zero
and ecx, edx
jz .the_bit_is_not_set
Используйте вторую группу только после инструкций CMP:
cmp eax, ebx
jne .eax_is_not_equal_to_ebx
cmp ecx, edx
ja .ecx_is_above_than_edx
Таким образом, программа станет более читаемой, и вы никогда не запутаетесь.
Обратите внимание, что иногда эти инструкции на самом деле являются синонимами. JZ == JE; JC == JB; JNC == JAE и так далее. Полная таблица приведена ниже. Как видите, есть только 16 инструкций условного перехода, но 30 мнемоник - они предназначены для создания более читаемого исходного кода:
Mnemonic Condition tested Description
jo OF = 1 overflow
jno OF = 0 not overflow
jc, jb, jnae CF = 1 carry / below / not above nor equal
jnc, jae, jnb CF = 0 not carry / above or equal / not below
je, jz ZF = 1 equal / zero
jne, jnz ZF = 0 not equal / not zero
jbe, jna CF or ZF = 1 below or equal / not above
ja, jnbe CF and ZF = 0 above / not below or equal
js SF = 1 sign
jns SF = 0 not sign
jp, jpe PF = 1 parity / parity even
jnp, jpo PF = 0 not parity / parity odd
jl, jnge SF xor OF = 1 less / not greater nor equal
jge, jnl SF xor OF = 0 greater or equal / not less
jle, jng (SF xor OF) or ZF = 1 less or equal / not greater
jg, jnle (SF xor OF) or ZF = 0 greater / not less nor equal
person
johnfound
schedule
12.02.2013