Bugs found in HBase 2.0:
id: EC_UNRELATED_TYPES, type: EC, category:CORRECTNESS
This method calls equals(Object) on two references of different class typeswith no common subclasses. Therefore, the objects being compared are unlikelyto be members of the same class at runtime (unless some application classeswere not analyzed, or dynamic class loading can occur at runtime). According tothe contract of equals(), objects of different classes should always compare asunequal; therefore, according to the contract defined byjava.lang.Object.equals(Object), the result of this comparison will always befalse at runtime.
id: EQ_COMPARETO_USE_OBJECT_EQUALS, type: Eq, category:BAD_PRACTICE
This class defines a compareTo(...) method but inherits its equals()method from java.lang.Object. Generally, the value of compareTo should returnzero if and only if equals returns true. If this is violated, weird andunpredictable failures will occur in classes such as PriorityQueue. In Java 5the PriorityQueue.remove method uses the compareTo method, while in Java 6 ituses the equals method.
From the JavaDoc for the compareTo method in the Comparable interface:
It is strongly recommended, but not strictly requiredthat (x.compareTo(y)==0) == (x.equals(y)). Generally speaking, any class thatimplements the Comparable interface and violates this condition should clearlyindicate this fact. The recommended language is "Note: this class has anatural ordering that is inconsistent with equals."
id: HE_EQUALS_USE_HASHCODE, type: HE, category:BAD_PRACTICE
This class overrides equals(Object), but does not override hashCode(), andinherits the implementation of hashCode() from java.lang.Object (which returnsthe identity hash code, an arbitrary value assigned to the object by theVM). Therefore, the class is very likely to violate the invariant thatequal objects must have equal hashcodes.
If you don't think instances of this class will ever be inserted into aHashMap/HashTable, the recommended hashCode implementation to use is:
public int hashCode() {
assert false :"hashCode not designed";
return 42; // anyarbitrary constant will do
}
id: CN_IDIOM_NO_SUPER_CALL, type: CN, category:BAD_PRACTICE
This non-final class defines a clone() method that does not callsuper.clone(). If this class ("A") is extended by a subclass("B"), and the subclass B calls super.clone(), then itis likely that B's clone() method will return an object of type A,which violates the standard contract for clone().
If all clone() methods call super.clone(), then they are guaranteed to useObject.clone(), which always returns an object of the correct type.
id: SC_START_IN_CTOR, type: SC, category:MT_CORRECTNESS
The constructor starts a thread. This is likely to be wrong if the classis ever extended/subclassed, since the thread will be started before thesubclass constructor is started.
id: DLS_DEAD_LOCAL_STORE, type: DLS, category:STYLE
This instruction assigns a value to a local variable, but the value is notread or used in any subsequent instruction. Often, this indicates an error,because the value computed is never used.
Note that Sun's javac compiler often generates dead stores for final localvariables. Because FindBugs is a bytecode-based tool, there is no easy way toeliminate these false positives.
id: EQ_ALWAYS_FALSE, type: Eq, category:CORRECTNESS
This class defines an equals method that always returns false. This meansthat an object is not equal to itself, and it is impossible to create usefulMaps or Sets of this class. More fundamentally, it means that equals is notreflexive, one of the requirements of the equals method.
The likely intended semantics are object identity: that an object is equalto itself. This is the behavior inherited from class Object. If you need tooverride an equals inherited from a different superclass, you can use use:
public boolean equals(Object o) { return this == o; }
id: IS2_INCONSISTENT_SYNC, type: IS, category:MT_CORRECTNESS
The fields of this class appear to be accessed inconsistently with respectto synchronization. This bug report indicates that the bug patterndetector judged that
A typical bug matching this bug pattern is forgetting to synchronize oneof the methods in a class that is intended to be thread-safe.
You can select the nodes labeled "Unsynchronized access" to showthe code locations where the detector believed that a field was accessedwithout synchronization.
Note that there are various sources of inaccuracy in this detector; forexample, the detector cannot statically detect all situations in which a lockis held. Also, even when the detector is accurate in distinguishinglocked vs. unlocked accesses, the code in question may still be correct.
Bug: Inconsistent synchronization oforg.apache.hadoop.hbase.client.HTable.currentWriteBufferSize; locked 75% of time
id: WMI_WRONG_MAP_ITERATOR, type: WMI, category:PERFORMANCE
This method accesses the value of a Map entry, using a key that wasretrieved from a keySet iterator. It is more efficient to use an iterator onthe entrySet of the map, to avoid the Map.get(key) lookup.
Bug: Method new org.apache.hadoop.hbase.client.Scan(Scan)makes inefficient use of keySet iterator instead of entrySet iterator
id: BC_IMPOSSIBLE_INSTANCEOF, type: BC, category:CORRECTNESS
This instanceof test will always return false. Although this is safe, makesure it isn't an indication of some misunderstanding or some other logic error.
id: ICAST_IDIV_CAST_TO_DOUBLE, type: ICAST, category:STYLE
This code casts the result of an integral division (e.g., int or longdivision) operation to double or float. Doing division on integers truncatesthe result to the integer value closest to zero. The fact that the result wascast to double suggests that this precision should have been retained. What wasprobably meant was to cast one or both of the operands to double beforeperforming the division. Here is an example:
int x = 2;
int y = 5;
// Wrong: yields result 0.0
double value1 = x/ y;
// Right: yields result 0.4
double value2 = x/ (double) y;
Bug: integral division result cast to double or float
id: DMI_INVOKING_HASHCODE_ON_ARRAY, type: DMI, category:CORRECTNESS
The code invokes hashCode on an array. Calling hashCode on an arrayreturns the same value as System.identityHashCode, and ingores the contents andlength of the array. If you need a hashCode that depends on the contents of anarray a, use java.util.Arrays.hashCode(a).
id: DMI_INVOKING_TOSTRING_ON_ARRAY, type:USELESS_STRING, category: CORRECTNESS
The code invokes toString on an array, which will generate a fairly uselessresult such as [C@16f0472. Consider using Arrays.toString to convert the arrayinto a readable String that gives the contents of the array. See ProgrammingPuzzlers, chapter 3, puzzle 12.
id: SWL_SLEEP_WITH_LOCK_HELD, type: SWL, category:MT_CORRECTNESS
This method calls Thread.sleep() with a lock held. This may result in verypoor performance and scalability, or a deadlock, since other threads may bewaiting to acquire the lock. It is a much better idea to call wait() on thelock, which releases the lock and allows other threads to run.
Bug:org.apache.hadoop.hbase.client.HConnectionManager$TableServers.getMaster()calls Thread.sleep() with a lock held
The method seems to be building a String using concatenation in a loop. Ineach iteration, the String is converted to a StringBuffer/StringBuilder,appended to, and converted back to a String. This can lead to a cost quadraticin the number of iterations, as the growing string is recopied in eachiteration.
Better performance can be obtained by using a StringBuffer (orStringBuilder in Java 1.5) explicitly.
For example:
// This is bad
String s ="";
for (int i = 0; i< field.length; ++i) {
s = s +field[i];
}
// This is better
StringBuffer buf= new StringBuffer();
for (int i = 0; i< field.length; ++i) {
buf.append(field[i]);
}
String s = buf.toString();
Bug: org.apache.hadoop.hbase.regionserver.LogRoller.run()does not release lock on all exception paths
id: UL_UNRELEASED_LOCK_EXCEPTION_PATH, type: UL, category:MT_CORRECTNESS
This method acquires a JSR-166 (java.util.concurrent
)lock, but does not release it on all exception paths out of the method. Ingeneral, the correct idiom for using a JSR-166 lock is:
Lock l = ...;
l.lock();
try {
// do something
} finally {
l.unlock();
}
id: DM_BOOLEAN_CTOR, type: Dm, category:PERFORMANCE
Creating new instances of java.lang.Boolean wastes memory, since Booleanobjects are immutable and there are only two useful values of this type. Use the Boolean.valueOf() method (or Java 1.5 autoboxing) to create Booleanobjects instead.
Bug:org.apache.hadoop.hbase.thrift.generated.ColumnDescriptor.getFieldValue(int)
Using new Integer(int) is guaranteed to always result in a new objectwhereas Integer.valueOf(int) allows caching of values to be done by thecompiler, class library, or JVM. Using of cached values avoids objectallocation and the code will be faster.
Values between -128 and 127 are guaranteed to have corresponding cachedinstances and using valueOf is approximately 3.5 times faster than usingconstructor. For values outside the constant range the performance of bothstyles is the same.
Unless the class must be compatible with JVMs predating Java 1.5, useeither autoboxing or the valueOf() method when creating instances of Long,Integer, Short, Character, and Byte.
Bug: Methodorg.apache.hadoop.hbase.client.TestClient.makeNAscii(byte[], int) invokesinefficient new Integer(int) constructor; use Integer.valueOf(int) instead
id: OS_OPEN_STREAM, type: OS, category:BAD_PRACTICE
The method creates an IO stream object, does not assign it to any fields,pass it to other methods that might close it, or return it, and does not appearto close the stream on all paths out of the method. This may result in afile descriptor leak. It is generally a good idea to use a finally blockto ensure that streams are closed.
Bug:org.apache.hadoop.hbase.io.hfile.RandomSeek.slurp(String) may fail to closestream
id: DE_MIGHT_IGNORE, type: DE, category:BAD_PRACTICE
This method might ignore an exception. In general, exceptions shouldbe handled or reported in some way, or they should be thrown out of the method.
Bug:org.apache.hadoop.hbase.ipc.HBaseServer$Connection.close() might ignorejava.lang.Exception
id: NP_BOOLEAN_RETURN_NULL, type: NP, category:BAD_PRACTICE
A method that returns either Boolean.TRUE, Boolean.FALSE or null is anaccident waiting to happen. This method can be invoked as though it returned avalue of type boolean, and the compiler will insert automatic unboxing of theBoolean value. If a null value is returned, this will result in aNullPointerException.
Bug: org.apache.hadoop.hbase.client.HTable$10.call()has Boolean return type and returns explicit null
id: NN_NAKED_NOTIFY, type: NN, category:MT_CORRECTNESS
A call to notify() or notifyAll() was made without any (apparent)accompanying modification to mutable object state. In general, calling anotify method on a monitor is done because some condition another thread iswaiting for has become true. However, for the condition to be meaningful,it must involve a heap object that is visible to both threads.
This bug does not necessarily indicate an error, since the change tomutable object state may have taken place in a method which then called themethod containing the notification.
id: GC_UNRELATED_TYPES, type: GC, category:CORRECTNESS
This call to a generic collection method contains an argument with anincompatible class from that of the collection's parameter (i.e., the type ofthe argument is neither a supertype nor a subtype of the corresponding generictype argument). Therefore, it is unlikely that the collection contains anyobjects that are equal to the method argument used here. Most likely, the wrongvalue is being passed to the method.
In general, instances of two unrelated classes are not equal. For example,if the Foo and Bar classes are not related by subtyping, then an instance ofFoo should not be equal to an instance of Bar. Among other issues, doing sowill likely result in an equals method that is not symmetrical. For example, ifyou define the Foo class so that a Foo can be equal to a String, your equalsmethod isn't symmetrical since a String can only be equal to a String.
In rare cases, people do define nonsymmetrical equals methods and stillmanage to make their code work. Although none of the APIs document or guaranteeit, it is typically the case that if you check if a Collection
id: NP_NULL_ON_SOME_PATH, type: NP, category:CORRECTNESS
There is a branch of statement that, if executed, guarantees that anull value will be dereferenced, which would generate a NullPointerExceptionwhen the code is executed. Of course, the problem might be that the branch orstatement is infeasible and that the null pointer exception can't ever beexecuted; deciding that is beyond the ability of FindBugs
id: UPM_UNCALLED_PRIVATE_METHOD, type: UPM, category:PERFORMANCE
This private method is never called. Although it is possible that themethod will be invoked through reflection, it is more likely that the method isnever used, and should be removed.
id: DMI_RANDOM_USED_ONLY_ONCE, type: BC, category:BAD_PRACTICE
This code creates a java.util.Random object, uses it to generate onerandom number, and then discards the Random object. This produces mediocrequality random numbers and is inefficient. If possible, rewrite the code sothat the Random object is created once and saved, and each time a new randomnumber is required invoke a method on the existing Random object to obtain it.
If it is important that the generated Random numbers not be guessable, youmust not create a new Random for each random number; the values are tooeasily guessable. You should strongly consider using ajava.security.SecureRandom instead (and avoid allocating a new SecureRandom foreach random number needed).
Bug: TestTableIndex
id: RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE, type:RCN, category: STYLE
This method contains a redundant check of a known non-null value againstthe constant null.
Pattern id: ICAST_INTEGER_MULTIPLY_CAST_TO_LONG, type:ICAST, category: STYLE
This code performs integer multiply and then converts the result to along, as in:
longconvertDaysToMilliseconds(int days) { return 1000*3600*24*days; }
If the multiplication is done using long arithmetic, youcan avoid the possibility that the result will overflow. For example, you couldfix the above code to:
longconvertDaysToMilliseconds(int days) { return 1000L*3600*24*days; }
or
static finallong MILLISECONDS_PER_DAY = 24L*3600*1000;
longconvertDaysToMilliseconds(int days) { return days * MILLISECONDS_PER_DAY; }
id: SIC_INNER_SHOULD_BE_STATIC, type: SIC, category:PERFORMANCE
This class is an inner class, but does not use its embedded reference tothe object which created it. This reference makes the instances of theclass larger, and may keep the reference to the creator object alive longerthan necessary. If possible, the class should be made static.
id: JLM_JSR166_UTILCONCURRENT_MONITORENTER, type:JLM, category: MT_CORRECTNESS
This method performs synchronization an object that is an instance of aclass from the java.util.concurrent package (or its subclasses). Instances ofthese classes have there own concurrency control mechanisms that are distinctfrom and incompatible with the use of the keyword synchronized.
id: FE_FLOATING_POINT_EQUALITY, type: FE, category:STYLE
This operation compares two floating point values for equality. Becausefloating point calculations may involve rounding, calculated float and doublevalues may not be accurate. For values that must be precise, such as monetaryvalues, consider using a fixed-precision type such as BigDecimal. For valuesthat need not be precise, consider comparing for equality within some range,for example: if ( Math.abs(x - y) < .0000001 ). See the Java LanguageSpecification, section 4.2.4.
id: UW_UNCOND_WAIT, type: UW, category:MT_CORRECTNESS
This method contains a call to java.lang.Object.wait() which is notguarded by conditional control flow. The code should verify thatcondition it intends to wait for is not already satisfied before calling wait;any previous notifications will be ignored.
id: URF_UNREAD_FIELD, type: UrF, category:PERFORMANCE
This field is never read. Consider removing it from the class.
id: SS_SHOULD_BE_STATIC, type: SS, category:PERFORMANCE
This class contains an instance final field that is initialized to acompile-time static value. Consider making the field static.
id: ICAST_QUESTIONABLE_UNSIGNED_RIGHT_SHIFT, type:BSHIFT, category: STYLE
The code performs an unsigned right shift, whose result is then cast to ashort or byte, which discards the upper bits of the result. Since the upperbits are discarded, there may be no difference between a signed and unsignedright shift (depending upon the size of the shift).
id: INT_VACUOUS_COMPARISON, type: INT, category:STYLE
There is an integer comparison that always returns the same value (e.g., x<= Integer.MAX_VALUE).