fcmpg :
single-precision float comparison (1 on NaN) : index : visitInsn()
- Description
- This takes two single-precision floating point numbers off the stack and
compares them, using IEEE 754 rules.
If the two numbers are the same, the integer 0 is pushed onto the stack. If
value2 is greater than value1, the integer 1 is pushed onto the
stack. If value1 is greater than value2, the integer -1 is pushed
onto the stack. If either number is NaN, the integer 1 is pushed onto the
stack. +0.0 and -0.0 are treated as equal. - Example
fload_1 ; push the float in local variable 1
fconst_0 ; push the float 0 onto the stack
fcmpl ; compare the two numbers
; The integer result on the stack is:
; 0 if local variable 1 equals 0
; -1 if local variable 1 is less than 0
; 1 if local variable 1 is greater than 0
- Notes
- This instruction is identical to fcmpl except for the treatment
of NaN.
- See also
- lcmp fcmpl dcmpl dcmpg
- Stack
Before
|
After |
value1 |
int-result |
value2 |
... |
... |
... |
- Bytecode
Type
|
Description |
u1
|
fcmpg
opcode = 0x96 (150)
|