equal方法和==的区别
如果是基本数据类型,用==比较的是其值,如果是复合数据类型,用==比较的是它们在内存中的存放地址,因此除非是同一个new出来的对象,否则比较结果都是false。此时想比较复合数据类型的值,应该用equal方法。
实例
两个Interger 数据做比较
Integer a=1;
Integer b=1;
Integer c=128;
Integer d=128;
System.out.println (a == b);
System.out.println (c == d);
System.out.println (a.equals ( b ));
System.out.println (c.equals ( d ));
运行结果
true
false
true
true
为什么会出现这种情况?
原因解析
用IDEA软件打开其对应的.class
文件,这个文件是.java
文件被编译成字节码之后,被反编译之后出来经过编译器(javac)自动装箱之后的具体代码
Integer a = Integer.valueOf(1);
Integer b = Integer.valueOf(1);
Integer c = Integer.valueOf(128);
Integer d = Integer.valueOf(128);
System.out.println(a == b);
System.out.println(c == d);
System.out.println(a.equals(b));
System.out.println(c.equals(d));
首先,用equal比较a和b,c和d的值,输出为true,这一点无可争议,那么为何a==b
的结果是true,而c==d
的结果却是false呢?这就要从Interger的valueOf()
方法说起
public static Integer valueOf(int var0) {
return var0 >= -128 && var0 <= Integer.IntegerCache.high?Integer.IntegerCache.cache[var0 + 128]:new Integer(var0);
}
//其中IntegerCache.high为assert high >= 127;
从上面valueOf的源码可以看出,对于-128~127
之间的值,valueOf()
方法直接返回一个在Integer缓存数组中的Integer,对于超过这个范围的值,此方法会new出来一个新的Integer用来返回。
这就解释了为什么a==b
为true,而c==d
为false了,前文提到过,==代表着比较在内存中的存放地址,a和b的值在-128~127
之间,因此都指向Integer的内存数组中的同一处,因此结果相等,c和d的值不在此范围内,因此指向了两个不同的对象,其内存地址不同,结果为false。