Wiki Markup |
---|
According to \[[JLS Section 4.2.3, Floating-Point Types, Formats, and Values|http://java.sun.com/docs/books/jls/third_edition/html/typesValues.html#4.2.3]\]: |
NaN is unordered, so the numerical comparison operators
<
,<=
,>
, and>=
returnfalse
if either or both operands areNaN
. The equality operator==
returnsfalse
if either operand isNaN
, and the inequality operator!=
returnstrue
if either operand isNaN
.
...
Problems can ensue arise when the programmer uses such operators on NaN
values in comparison operations. There is also a possibility that the input validation condition does not expect a NaN
value as input.
...
A frequently encountered mistake is the doomed comparison with NaN
, typically in expressions. As per its semantics, no value (including NaN
itself) can be compared to NaN
using common operators, including NaN
itself. This noncompliant example demonstrates one of such casesviolations.
Code Block | ||
---|---|---|
| ||
public class NaNComparison { public static void main(String[] args) { double x = 0.0; double result = Math.cos(1/x); // returns NaN if input is infinity if(result == Double.NaN) // compare with infinity System.out.println("Both are equal"); } } |
...
Risk Assessment
Comparisons with NaN
values may lead to unexpected results.
Rule | Severity | Likelihood | Remediation Cost | Priority | Level |
---|---|---|---|---|---|
FLP02-J | low | unlikely probable | low medium | P3 P4 | L3 |
Automated Detection
TODO
...