理解intern

 下面是为了理解intern
String a = "hello";
        String b =  new String("hel") + new String("lo");

        String d = b.intern();

        System.out.println(a==d);
        System.out.println(a==b);

        String cc = "hello2";//注释掉和保留会影响下面的结果
        String bb =  new String("hel") + new String("lo2");
//        String bb =  new String("hello2") ;
        String dd = bb.intern();
        String aa = "hello2";
        System.out.println(dd==aa);
        System.out.println(aa==bb);
//        System.out.println(aa==cc);


首先用分段new排除在常量池创建了hello hello2的可能
其次更好的测试出了JDK1.7以后的intern机制
1常量池分为class文件常量池和运行时常量池,目前可以确定的是String常量池1.7后改为存在堆中。但是和NEW出来的值存放的堆空间不一样。
2当
String bb =newString("hello2");
String dd = bb.intern();
String aa ="hello2";
System.out.println(dd==aa);
System.out.println(aa==bb);
时,在堆和字符串常量池都会创建一个hello,这是2个不同的对象,所以aa != bb,而dd指向常量池已有的,所以与aa指向一致,dd == aa
3当
String bb =newString("hel") +newString("lo2");
//        String bb =  new String("hello2") ;
String dd = bb.intern();
String aa ="hello2";
System.out.println(dd==aa);
System.out.println(aa==bb);
时,只有堆中有hello2,常量池中没有,dd此时不会在常量池创建“hello2”(JDK1.6会),而是在常量池创建一个指向bb的引用,aa也指向这个引用,所以aa==bb。这里不好理解就在于为什么常量池没有存具体值而是引用了,就是因为字符串常量池在1.7改为存在堆里了,大家都在堆里用一个值没毛病。
4
String cc ="hello2";//注释掉和保留会影响下面的结果
String bb =newString("hel") +newString("lo2");
//        String bb =  new String("hello2") ;
String dd = bb.intern();
String aa ="hello2";
System.out.println(dd==aa);
System.out.println(aa==bb);
时就好理解了,常量池有“hello2”,dd指向常量池的“hello2”,aa也是,bb还是堆中的。 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值