W kodzie asemblera x86 są JE
i są JNE
dokładnie takie same jak JZ
i JNZ
?
W kodzie asemblera x86 są JE
i są JNE
dokładnie takie same jak JZ
i JNZ
?
Odpowiedzi:
JE
i JZ
są po prostu różnymi nazwami dla dokładnie tego samego: skok warunkowy, gdy ZF
(flaga „zero”) jest równa 1.
(Podobnie, JNE
i JNZ
to tylko różne nazwy dla skoku warunkowego, gdy ZF
jest równa 0.)
Państwo mogli używać ich zamiennie, ale należy z nich korzystać w zależności od tego, co robisz:
JZ
/ JNZ
są bardziej odpowiednie, gdy jawnie testujesz coś równego zero:
dec ecx
jz counter_is_now_zero
JE
i JNE
są bardziej odpowiednie po CMP
instrukcji:
cmp edx, 42
je the_answer_is_42
( CMP
Instrukcja wykonuje odejmowanie i odrzuca wartość wyniku, zachowując flagi; dlatego otrzymujesz, ZF=1
gdy operandy są równe, a ZF=0
kiedy nie).
jb
/ jc
/ jnae
wszystkie testy CF = 1. Zobacz felixcloutier.com/x86/jcc (lub cmovcc lub setcc)
Z podręcznika Intela - Odniesienie do zestawu instrukcji , JE
i JZ
mają ten sam kod 74
operacji ( dla rel8 / 0F 84
dla rel 16/32), JNE
a także JNZ
( 75
dla rel8 / 0F 85
dla rel 16/32) współdzielą kody operacyjne.
JE
i JZ
oba sprawdzają ZF
flagę (lub zero), chociaż podręcznik różni się nieco w opisach pierwszego JE
użycia rel8 i JZ
rel8 ZF
, ale w zasadzie są takie same.
Oto wyciąg ze stron podręcznika 464, 465 i 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).