Java字符串比较必须用.equals()而非==,因==判断引用地址而.equals()判断内容;推荐"str".equals(s)防null;忽略大小写用.equalsIgnoreCase()但需注意Locale问题。

Java里字符串比较不能直接用==判断内容是否相等,必须用.equals()方法——这是最常踩的坑。
用equals()比较字符串内容
==比较的是两个引用是否指向同一块内存地址,而.equals()才真正比字符序列是否一致。
- 正确写法:
"hello".equals(str)(推荐把字面量放前面,避免str为null时抛NullPointerException) - 错误写法:
str == "hello"或str.equals("hello")(当str为null时会崩溃) - 忽略大小写用
.equalsIgnoreCase(),比如"Hello".equalsIgnoreCase("HELLO")返回true
注意字符串常量池和new String()
直接写"abc"会进字符串常量池,多次出现相同字面量通常复用同一对象;但new String("abc")一定在堆上新建对象,即使内容一样,==也返回false。
-
"abc" == "abc"→ true(常量池中同一个对象) -
new String("abc") == new String("abc")→ false(两个不同堆对象) -
new String("abc").equals("abc")→ true(内容相同)
需要严格按顺序/大小写/空格判断时别忽略细节
字符串比较对空格、大小写、不可见字符(如\u200B零宽空格)极其敏感。实际开发中容易因前后空格或编码差异导致误判。
立即学习“Java免费学习笔记(深入)”;
- 比较前建议先调用
.trim()去除首尾空白 - 涉及用户输入或外部数据时,考虑用
Objects.equals(a, b)(自动处理null) - 需要精确到Unicode级别(比如国际化场景),可用
String.compareTo()或Collator类
不区分大小写的比较要小心locale问题
.equalsIgnoreCase()基于默认Locale,某些语言(如土耳其语)中i/I的映射不遵循英语规则,可能出错。
- 一般场景够用,但做系统级或国际化服务时,建议显式指定Locale:
str.toUpperCase(Locale.ENGLISH).equals(other.toUpperCase(Locale.ENGLISH)) - 或者用
java.text.Collator配合Collator.PRIMARY强度做更健壮的比较










