Очевидный ответ на вопрос уже дан , но здесь есть предупреждение, которое не является прямым ответом: obj.equals
также может дать сбой, если obj равно нулю.Поэтому вам часто приходится использовать код, подобный следующему:
if(mystr1 != null && mystr1.equals(mystr2))
, потому что это
if(mystr1.equals(mystr2))
завершится с ошибкой NullPointerException, если mystr1 будет нулевым.
почему, когда строка сравнения является известной константой, часто используется следующий синтаксис:
if("ABCDEF".equals(mystr1))
вместо
if(mystr1.equals("ABCDEF"))
По этой причине многие библиотеки (например, apachecommons / lang ) предоставляет служебные функции, которые объединяют эти проверки:
// this is the definition of org.apache.commons.lang.StringUtils.equals(String, String)
public static boolean equals(String str1, String str2) {
return str1 == null ? str2 == null : str1.equals(str2);
}
// this is the definition of org.apache.commons.lang.ObjectUtils.equals(Object, Object)
public static boolean equals(Object object1, Object object2) {
if (object1 == object2) {
return true;
}
if ((object1 == null) || (object2 == null)) {
return false;
}
return object1.equals(object2);
}
Использование этих методов обычно безопаснее, чем равные, если только вы точно не знаете, что один из двух объектов не равен нулю