Java String的intern方法 在JDK6和JDK7的不同行为

String str1 = new StringBuilder("a").append("b").toString();  //1
System.out.println(str1.intern() == str1);                    //2
String str2 = new StringBuilder("c").toString();              //3
System.out.println(str2.intern() == str2);                    //4

java 内存模型中存在一个叫做 String常量池的区域,其中存放着字符串常量。

首先说明一下,在jdk版本小于等于1.6的时候,执行上述代码的结果会是

false
false

jdk 版本大于1.6 时,上述代码的执行结果为

true
false

造成以上两种不同结果的原因是,jvm对 intern()方法的实现不同。

在jdk1.6及以前,调用intern()

如果常量池中不存在值相等的字符串时,jvm会复制一个字符串到创量池中,并返回常量池中的字符串。

而在jdk1.7及以后,调用intern()

如果常量池中不存在值相等的字符串时,jvm只是在常量池记录当前字符串的引用,并返回当前字符串的引用。

接下来,我们再解释上述代码在jdk1.7及以上jdk中为什么会得到一个true一个false。

当存在上述代码的类被JVM加载时,字面值常量 a, b, c 就会被加载到 String 常量池中(注意,这是在编译阶段就确定了的常量字符串)。

当执行str1.intern()时,由于常量池中并不存在字符串ab,jvm 会在常量池中记录str1的引用,并返回str1的引用,因此,第2行代码的输出为true。

str2使用字面值常量 c构造了一个新的字符串(正如上面说的一样,'c'已经在编译阶段就确定下来了,在类加载时候就加载到String 常量池中了),该字符串的引用和常量池中字面值c字符串的引用不相同,当调用str2.intern()时, 常量池中已经存在了c,jvm直接返回常量池中的引用,该引用不同于重新构造的str2,因此第4行代码的输出为false。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值