1.“==”两端比较的是基本数据类型,判断基本数据类型的值是否相等,相等就返回true,否则返回false,重点是值,数据类型可能不同,例如:
.
2.“==”两端比较的是引用类型,判断的是引用类型变量的地址值是否相等,例如:
.
equals(Object obj)的相关知识
源码如下所示:
.
equals(Object obj)处理引用类型变量,在源码中发现还是比较的还是地址值。
.
String类也是继承了Object类,按理说比较的是地址值也,应该为false,怎么会为true呢?因为String类重写了equals()方法,源码如下:
.
其实不仅String类重写了equals()方法,还有包装类,File类,Date类都重写了Object类的equals()方法,比较两个对象的“实体内容”是否相同,如果我们自己定义的类,希望两个对象的属性值都相同的情况下返回true,就需要重写equals()方法。当然,我们可以仿照String类重写equals()方法来重写自己的定义类中的equals()方法,还是有难度,可以使用eclipse自动生成的equlas()方法,例如Person类,如下所示:
.
当然这里也存在一些常识性的操作,例如对于非空对象引用x,y,z
.
equals()方法和“==”使用场景
.
toString()方法
toString()也是Object类中使用频率很高的方法,使用情况如下所示:
.
结果如下:
.
Object类中toString()方法的源码如下:
.
如果子类没有重写toString()方法,当我们打印一个对象的引用时,实际调用的就是Object类中的toString()方法。输出此对象所在类及对应的堆空间对象的首地址。如果子类重写了toString()方法,那么打印一个对象引用时,实际上调用的就是当前对象的toString()方法例如Person类重写了toString()方法
.
看下面两个例子:
.
结果为:
.
输出结果不是我们前面所说的地址值,这是因为String类重写了toString()方法,源码如下:
.
其实像String类,File类,Date类,包装类都重写了toString()方法。