最近面试遇到两道'=='与equals的题,觉得比较有代表性,特别记录下来,以及详解这两者。
下面直接上题例:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
public
class
Square {
long
width;
public
Square(
long
l) {
width = l;
}
public
static
void
main(String arg[]) {
Square a, b, c;
a =
new
Square(42L);
b =
new
Square(42L);
c = b;
long
s = 42L;
}
}
a == b s == a b == c a.equals(s) 参考解析:
如图所示:
来看4个选项:
A: a == b
由图可以看出a和b指向的不是同一个引用,故A错
B:s == a
一个Square类型不能与一个long型比较,编译就错误,故B错
c:b == c
由图可以看出b和c指向的是同一个引用,故C正确
d:a equal s
程序会把s封装成一个Long类型,由于Square没有重写Object的equals方法, 所以调用的是Object类的equals方法,源码如下
在jdk1.5的环境下,有如下4条语句:
以下输出结果为false的是:
System.out.println(i01== i02); System.out.println(i01== i03); System.out.println(i03== i04); System.out.println(i02== i04);
Integer i01=59 的时候,会调用 Integer 的 valueOf 方法,
这个方法就是返回一个 Integer 对象,只是在返回之前,看作了一个判断,判断当前 i 的值是否在 [-128,127] 区别,且 IntegerCache 中是否存在此对象,如果存在,则直接返回引用,否则,创建一个新的对象。 在这里的话,因为程序初次运行,没有 59 ,所以,直接创建了一个新的对象。
int i02=59 ,这是一个基本类型,存储在栈中。
Integer i03 =Integer.valueOf(59); 因为 IntegerCache 中已经存在此对象,所以,直接返回引用。
Integer i04 = new Integer(59) ;直接创建一个新的对象。
System. out .println(i01== i02); i01 是 Integer 对象, i02 是 int ,这里比较的不是地址,而是值。 Integer 会自动拆箱成 int ,然后进行值的比较。所以,为真。 行值的比较。所以,为真。 System. out .println(i01== i03); 因为 i03 返回的是 i01 的引用,所以,为真。
System. out .println(i03==i04); 因为 i04 是重新创建的对象,所以 i03,i04 是指向不同的对象,因此比较结果为假。
System. out .println(i02== i04); 因为 i02 是基本类型,所以此时 i04 会自动拆箱,进行值比较,所以,结果为真。
下面再看一个例子:
public static void main(String[] args) {
String a=new String("computer"); String b=new String("computer"); String c="computer"; String d="computer"; System.out.println(a==b); System.out.println(a==c); System.out.println(a.equals(b)); System.out.println(a.equals(c)); System.out.println(c==d); } 结果为: false
通过这几个例子,最后总结一下 '=='与equals:
1. == 是一个运算符。 2.equals则是string对象的方法,可以.(点)出来。 我们比较无非就是这两种 1、基本数据类型比较 2、引用对象比较 1、基本数据类型比较 ==和equals都比较两个值是否相等。相等为true 否则为false; 2、引用对象比较==比较栈内存中地址是否相等;而equals比较的是两个地址指向的对象是不是同一个,也就是对象的值是否相同。
|