在Java里如何使用字符串比较_Java字符串比较注意事项说明

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零宽空格)极其敏感。实际开发中容易因前后空格或编码差异导致误判。

  • 比较前建议先调用.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强度做更健壮的比较