guangzhanzb
2017-04-07 07:45
采纳率: 66.7%
浏览 1.7k
已采纳

Java基本数据类型字面量在JVM中如何申请内存

有如下三段代码,A、B、C。
其中A段代码中,i1、i2打印出来的HashCode是一样的,这个我可以理解,因为127在常量池中是有缓存的。
B段代码中,i3、i4打印出来的HashCode是不一样的,我认为这说明在常量池中存在两个128的字面量,这样理解对吗?
C段代码中,照我想来,应该是在常量池中只有一个235的字面量,然后i5、i6应该是分别指向这个字面量的,所以打出来的HashCode也应该是一致的,但是在我机器上跑的结果却是不一致,这是为什么?
如果是我的理解出现了偏差,那么应该如何理解呢?

        //A
        int i1 = 127;
        int i2 = 127;
        System.out.printf("i1~%d\ti2~%d\n", System.identityHashCode(i1), System.identityHashCode(i2));

        //B
        int i3 = 128;
        int i4 = 128;
        System.out.printf("i3~%d\ti4~%d\n", System.identityHashCode(i3), System.identityHashCode(i4));

        //C
        int i5 = 235;
        int i6 = i5;
        System.out.printf("i5~%d\ti6~%d\n", System.identityHashCode(i5), System.identityHashCode(i6));
  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • zsc我行我素 2017-04-07 08:05
    已采纳

    int 基本类型常量池中只有-127到127,所以B段代码打印的hashcode是不一样的

    int是基本数据类型,赋值的时候是值传递,所以int i6 = i5; 相当于又生成了一个235对象,

    C段代码如果改成Integer i5 = 235; Integer i6=i5;这时候打印的hashcode就是一样的

    点赞 评论

相关推荐 更多相似问题