首先感谢http://my.oschina.net/heguangdong/blog/141053 博文的提示。
装箱调用的是valueOf()方法(应该是编译器执行的)。还是拿Long类型举例(Integer是一样的)
源码如下:
public static Long valueOf(long l) {
final int offset = 128;
if (l >= -128 && l <= 127) { // will cache
return LongCache.cache[(int)l + offset];
}
return new Long(l);
} 而LongCache中维护了-128到127的一个常量池,故这些常量对象只会一份不会再new。
private static class LongCache {
private LongCache(){}
static final Long cache[] = new Long[-(-128) + 127 + 1];
static {
for(int i = 0; i < cache.length; i++)
cache[i] = new Long(i - 128);
}
} 让我们再看看Double的源码:
public static Double valueOf(double d) {
return new Double(d);
} 每次都是new 的一个对象。这样就解释了为什么Double型不能用==的原因。
另外得注意Long Integer类型使用==的条件。(-128到127)
Java装箱与常量池揭秘
本文深入探讨Java中Long和Integer类型的装箱机制,揭示valueOf方法如何利用常量池提高效率,以及Double类型为何每次都会创建新对象。特别关注-128到127范围内的数值处理,解析==运算符在基本类型与包装类型间的适用性。
776

被折叠的 条评论
为什么被折叠?



