FindBugs Bug Descriptions

FindBugs Bug Descriptions

◇例1:

Integer a = 123;
String str ="123";
System.out.println(str == a.toString());

◇结果:

Rank: Scary (9), confidence: High
Pattern: ES_COMPARING_STRINGS_WITH_EQ
Type: ES, Category: BAD_PRACTICE (Bad practice)

◇ES_COMPARING_STRINGS_WITH_EQ的说明:

这段代码使用== or !=操作符来进行String对象的引用比较。

除非代码中的两个字符串都是常量或者使用了String.intern()方法返回新的字符串引用(这个引用能保证指向的是同一个地址),否则两个字符串的值很可能代表两个不同的String对象。考虑使用equals(Object)代替。

也就是说上述代码的返回值总是false。原因就是他们比较的是引用而不是值。所以如果只是想比较两个字符串的值是否相等,总是使用equals(Object)方法更好。

-----------------------------------------------------------------------------------------------

◇例2:

Integer a = 123;
String str ="123";
System.out.println(str.equals(a));

◇结果:

Rank: Scariest (1), confidence: High
Pattern: EC_UNRELATED_TYPES
Type: EC, Category: CORRECTNESS (Correctness)

◇EC_UNRELATED_TYPES的说明:

这段代码在两个不同类型的引用上调用equals(Object)方法。分析表明他们在运行时会变成两个不同类对象。另外,对这个equals方法的测试表明这个调用总是返回false,或者这个equals方法是不均衡的(均衡是Object类的equals方法的必须的一个属性)。

 *********************************************************************

例1和例2的解决:使用Equals方法+将两个对象转换为相同的类型再比较

 *********************************************************************

Eclipse findbugs找到的bug案例说明

原文地址:https://www.cnblogs.com/niaomingjian/p/4875194.html