首先我们要明白Integer是引用数据类型,是包装类(封装类) 1.5版本之后,存在自动拆装包。他是int类型对应的封装类。
Integer是直接继承于Number类间接继承于Object类 ,实现了Comparable接口。

下面看实例:
Integer i1 = 10;
Integer i2 = 10;
Integer i3 = new Integer(10);
Integer i4 = new Integer(10);
System.out.println(i1 == i2); //true
System.out.println(i1 == i3); //false
System.out.println(i3 == i4); //false
System.out.println(i1.equals(i2)); //true
System.out.println(i1.equals(i3)); //true
System.out.println(i3.equals(i4)); //true
而为什么又会出现下面这种情况呢?
Integer i1 = 1000;
Integer i2 = 1000;
Integer i3 = new Integer(1000);
Integer i4 = new Integer(1000);
System.out.println(i1 == i2); //false
System.out.println(i1 == i3); //false
System.out.println(i3 == i4); //false
System.out.println(i1.equals(i2)); //true
System.out.println(i1.equals(i3)); //true
System.out.println(i3.equals(i4)); //true
原因:
这里我们要明白Integer类型的对象用"=="和用equals比较时的区别
==可以比较基本数据类型,也可以比较引用数据类型(变量中存储的内容),如果比较基本数据类型比较的时变量中存储的值,如果比较引用数据类型比较的时变量中存储的地址引用,equals()时Object类中继承过来的方法,每一个引用数据类型都可以调用。默认继承于Object类中的equals()方和==比较的一致,如果想要改变比较的规则,就需要重写equals方法,由于Integer类重写了equals()方法,所以Integer比较的数值。
下面分别是Object类中的equals方法和Integer类中的方法
Object类中的equals方法:
public boolean equals(Object obj) {
return (this == obj);
}

Integer类中重写的equals方法:
public boolean equals(Object obj) {
if (obj instanceof Integer) {
return value == ((Integer)obj).intValue();
}
return false;
}

还有就是考察了Integer类加载的时候,它就创建了自己的静态空间,立即加载了Integer类型的数组,数组内存储了256个Integer类型的对象-128 - 127,如果我们用的对象范围在这之内,如Ingeger i1 = 10;JVM就会直接从静态区的Integer类型的数组中直接找对应的对象,如果我们用的对象范围超出了这个,例如Integer i1 = 1000;JVM就会帮我们在堆内存中创建一个新的Integer对象。
如下便是Integer类中的内部类IntegerCache,就是该内部类类在静态空间中创建了Integer类型的静态数组cache[]。
private static class IntegerCache {
static final int low = -128;
static final int high;
static final Integer cache[];
static {
// high value may be configured by property
int h = 127;
String integerCacheHighPropValue =
sun.misc.VM.getSavedProperty("java.lang.Integer.IntegerCache.high");
if (integerCacheHighPropValue != null) {
try {
int i = parseInt(integerCacheHighPropValue);
i = Math.max(i, 127);
// Maximum array size is Integer.MAX_VALUE
h = Math.min(i, Integer.MAX_VALUE - (-low) -1);
} catch( NumberFormatException nfe) {
// If the property cannot be parsed into an int, ignore it.
}
}
high = h;
cache = new Integer[(high - low) + 1];
int j = low;
for(int k = 0; k < cache.length; k++)
cache[k] = new Integer(j++);
// range [-128, 127] must be interned (JLS7 5.1.7)
assert IntegerCache.high >= 127;
}
private IntegerCache() {}
}
源代码在Integer类中的780开始到812行结束。

总结:一定要明白==号比较基本类型比较的时值,比较引用类型比较的是地址,equals()方法是Object类中的方法,比较的时候一定要明白参与比较的类是否重写了equals()方法,重写后的比较规则是什么样的,引用数据类型的对象到底是创建在哪里的,万变不离其宗,掌握正确的比较规则,才能灵活的掌握这样中比较方式的区别。
感谢阅读,别忘了一键三连支持一下博主哟,谢谢~。
本文详细解析了Java中Integer对象与基本类型int使用`==`和`equals()`进行比较时的区别。Integer对象在-128至127之间会使用缓存,超出此范围则每次都会新建对象。`==`比较的是对象引用,而Integer重写了`equals()`方法,用于比较数值。理解这些区别对于Java编程至关重要。
1134

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



