下面的代码中字符串文字的行为非常令人困惑。
我可以理解第 1 行、第 2 行和第 3 行是true
,但为什么是第 4 行false
?
当我打印两者的哈希码时,它们是相同的。
class Hello
{
public static void main(String[] args)
{
String hello = "Hello", lo = "lo";
System.out.print((Other1.hello == hello) + " "); //line 1
System.out.print((Other1.hello == "Hello") + " "); //line 2
System.out.print((hello == ("Hel"+"lo")) + " "); //line 3
System.out.print((hello == ("Hel"+lo)) + " "); //line 4
System.out.println(hello == ("Hel"+lo).intern()); //line 5
System.out.println(("Hel"+lo).hashCode()); //hashcode is 69609650 (machine depedent)
System.out.println("Hello".hashCode()); //hashcode is same WHY ??.
}
}
class Other1 { static String hello = "Hello"; }
我知道==
检查引用相等性并检查池中的文字。我知道equals()
是正确的方法。我想理解这个概念。
我已经检查过了question https://stackoverflow.com/questions/9865270/java-string-pool-and-type-casting,但是没有解释清楚。
我希望得到完整的解释。
Every 编译时常量表达式 http://docs.oracle.com/javase/specs/jls/se7/html/jls-15.html#jls-15.28这是类型String
将被放入字符串池中。
本质上这意味着:如果编译器可以(轻松地)“计算”String
如果不运行程序,那么它将被放入池中(规则比这稍微复杂一些,并且有一些极端情况,请参阅上面的链接了解所有详细信息)。
对于第 1-3 行中的所有字符串都是如此。
"Hel"+lo
is not编译时常量表达式,因为lo
是一个非常量变量。
哈希码是相同的,因为字符串的 hashCode 仅取决于其内容 http://docs.oracle.com/javase/7/docs/api/java/lang/String.html#hashCode%28%29。这是合同所要求的equals() http://docs.oracle.com/javase/7/docs/api/java/lang/String.html#equals%28java.lang.Object%29 and hashCode()
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)