В ассемблерном коде x86 are JE
и JNE
точно такие же, как JZ
и JNZ
?
В ассемблерном коде x86 are JE
и JNE
точно такие же, как JZ
и JNZ
?
Ответы:
JE
и JZ
представляют собой просто разные имена для одного и того же: условного перехода, когда ZF
(флаг «ноль») равен 1.
(Точно так же JNE
и JNZ
- это просто разные имена для условного перехода, когда ZF
он равен 0.)
Вы можете использовать их как взаимозаменяемые, но вы должны использовать их в зависимости от того, что вы делаете:
JZ
/ JNZ
более подходят, когда вы явно тестируете что-то равное нулю:
dec ecx
jz counter_is_now_zero
JE
и JNE
более уместны после CMP
инструкции:
cmp edx, 42
je the_answer_is_42
(Команда CMP
выполняет вычитание и отбрасывает значение результата, сохраняя при этом флаги; вот почему вы получаете, ZF=1
когда операнды равны, а ZF=0
когда нет.)
jb
/ jc
/ jnae
все испытания CF = 1. См. Felixcloutier.com/x86/jcc (или cmovcc, или setcc)
От руководства компании Intel - Instruction Set Reference , то JE
и JZ
имеют один и тот же код операции ( 74
для rel8 / 0F 84
для отн 16/32) также JNE
и JNZ
( 75
для rel8 /0F 85
для отна 16/32) Доля Opcodes.
JE
и JZ
они оба проверяют наличие ZF
(или нулевого флага), хотя в руководстве немного отличаются описания первых JE
rel8 иJZ
rel8 ZF
, но в основном они одинаковы.
Вот выдержка из страниц 464, 465 и 467 руководства.
Op Code | mnemonic | Description
-----------|-----------|-----------------------------------------------
74 cb | JE rel8 | Jump short if equal (ZF=1).
74 cb | JZ rel8 | Jump short if zero (ZF ← 1).
0F 84 cw | JE rel16 | Jump near if equal (ZF=1). Not supported in 64-bit mode.
0F 84 cw | JZ rel16 | Jump near if 0 (ZF=1). Not supported in 64-bit mode.
0F 84 cd | JE rel32 | Jump near if equal (ZF=1).
0F 84 cd | JZ rel32 | Jump near if 0 (ZF=1).
75 cb | JNE rel8 | Jump short if not equal (ZF=0).
75 cb | JNZ rel8 | Jump short if not zero (ZF=0).
0F 85 cd | JNE rel32 | Jump near if not equal (ZF=0).
0F 85 cd | JNZ rel32 | Jump near if not zero (ZF=0).