rspec/rules/S1764/java/rule.adoc

50 lines
1019 B
Plaintext
Raw Normal View History

2020-06-30 12:47:33 +02:00
include::../description.adoc[]
== Noncompliant Code Example
----
if ( a == a ) { // always true
doZ();
}
if ( a != a ) { // always false
doY();
}
if ( a == b && a == b ) { // if the first one is true, the second one is too
doX();
}
if ( a == b || a == b ) { // if the first one is true, the second one is too
doW();
}
int j = 5 / 5; //always 1
int k = 5 - 5; //always 0
c.equals(c); //always true
----
== Exceptions
* This rule ignores ``++*++``, ``+``, and ``++=++``.
2021-01-27 13:42:22 +01:00
* The specific case of testing a floating point value against itself is a valid test for ``++NaN++`` and is therefore ignored.
2020-06-30 12:47:33 +02:00
* Similarly, left-shifting 1 onto 1 is common in the construction of bit masks, and is ignored.
----
float f;
if(f != f) { //test for NaN value
System.out.println("f is NaN");
}
int i = 1 << 1; // Compliant
int j = a << a; // Noncompliant
----
include::../see.adoc[]
ifdef::rspecator-view[]
== Comments And Links
(visible only on this page)
include::comments-and-links.adoc[]
endif::rspecator-view[]