如果是你自己定义的一个类,比较自定义类用equals和==是一样的,都是比较句柄地址, 因为自定义的类是继承于object,而object中的equals就是用==来实现的。
运行结果:false true true false true
采用new 创建的字符串对象不进入字符串池,
字符串相加的时候,都是静态字符串的结果会添加到字符串池,如果其中含有变量(如f中的e)则不会进入字符串池中。
在定义变量的时候赋值,如果赋值的是静态的字符串,就会执行进入字符串缓冲池的操作,如果池中含有该字符串,则返回引用。
以int和Integer为例说明 Java中int和Integer区别如下:
1.int是基本的数据类型,默认值可以为0;Integer是int的封装类,默认值为null;
2.int和Integer都可以表示某一个数值,但int和Integer不能够互用,因为他们两种不同的数据类型;
int a1=1;
int a2=1;
Integer b1 =new Integer (1);
Integer b2 =new Integer (1);
Answer:
a1==a2 这个是成立的,很简单,都知道
a1==b1 这个是不成立的.表达式的值为 false ,它们是不同的数据类型(在jdk1.5以上版本中为true)
b1==b2 这个也是不成立的.表达式的值为 false,虽然是相同的数据类型,但是它们是两个对象,==比较的是2个对象的地址,它们的地址是不相等的,内容相等都是1;
b1.equals(b2)==true 这个是成立的,表达式的值为 true. 相同数据类型,两个对象,地址不同,内容相同, quals比较的是2个对象的内容,所以成立。
(a.equals(b),因为equals比较的是两个对象,所以a,b都不能为基本数据类型,否则会出编译错误。)(在jdk1.5以上版本中,b可以为基本数据类型,a不可以) 同理,其它的封装类和基本类型也是这样
在jdk1.5以上的版本中,基本类型和封装类能自动转化,与String类型的对象和字符串常量类似。
Integer i1 = 123;
Integer i2 = 123;
int i = 123;
Integer i3 = new Integer(123); Integer i4 = new Integer(123);
System.out.println("i1 == i2 = "+(i1 == i2));
System.out.println("i1.equals(i2) = "+(i1.equals(i2)));
System.out.println();
System.out.println("i3 == i4 = "+(i3 == i4));
System.out.println("i3.equals(i4) = "+(i3.equals(i4)));
System.out.println();
System.out.println("i2 == i4 = "+(i2 == i4));
System.out.println("i2.equals(i4) = "+(i2.equals(i4)));
System.out.println();
System.out.println("i == i2 = "+(i == i2));
System.out.println("i1.equals(i) = "+(i1.equals(i)));
System.out.println();
System.out.println("i == i4 = "+(i == i4));
System.out.println("i4.equals(i) = "+(i4.equals(i)));
Answer:
i1 == i2 = true
i1.equals(i2) = true
i3 == i4 = false
i3.equals(i4) = true
i2 == i4 = false
i2.equals(i4) = true
i == i2 = true
i1.equals(i) = true
i == i4 = true
i4.equals(i) = true
1.new Object(),JVM根据这个对象的Hashcode值,放入到对应的Hash表对应的Key上,如果发生了Hash key相同导致冲突的情况,那么就在这个Hash key的地方产生一个链表,将所有产生相同hashcode的对象放到这个单链表上去。
2.比较两个对象的时候,首先根据他们的hashcode去hash表中找他的对象,当两个对象的hashcode相同,那么就是说他们这两个对象放在Hash表中的同一个key上,那么他们一定在这个key上的链表上。那么此时就只能根据Object的equal方法来比较这个对象是否equal。当两个对象的hashcode不同的话,肯定他们不能equal.
两个相等对象的equals方法一定为true, 但两个hashcode相等的对象不一定是相等的对象。