int i=0;
Integer j = new Integer(0);
System.out.println(i==j);
System.out.println(j.equals(i));
方法一考虑
一、
1、
==需要看情况,得看比较的是基本数据类型还是引用数据类型 1、若是比较的是基本数据类型,直接看值,若是值在【-128,127】且相等,则比较相等;若值不在【-128,127】或者两个数的值不相等,则比较为不等。
2、
若是比较的是引用数据类型(比如new与new)(或者new 与 基本数据类型),即使值相等,也会比较为不相等。
二、
equals比较是值,只要值相等即可
方法二考虑
一、比较的是值
1、基本数据类型与引用数据类型进行比较时,引用数据类型会进行拆箱,然后与基本数据类型进行值的比较
举例:
int i = 9;
Integer j = new Integer(9);
i == j 返回的是true
2、引用数据类型与基本数据类型进行比较,基本数据类型会进行自动装箱,与引用数据类型进行比较,Object中的equals方法比较的是地址,但是Integer类已经重写了equals方法,只要两个对象的值相同,则可视为同一对象,具体看API文档,所以这归根到底也是值的比较!
举例:
int i = 2;
Integer j = new Integer(2);
j.equals(i) 返回的是true
二、比较的是地址
1、如果引用数据类型是这样 Integer i = 12;直接从常量池取对象,这是如果数值是在-128与127之间,则视为同一对象,否则视为不同对象
举例
Integer i = 9; Integer j = 9;
i == j 返回的是true
Integer i = 128; Integer j = 128;
i == j 返回的是false
2、如果引用数据类型是直接new的话,不管值是否相同,这时两个对象都是不相同的,因为都会各自在堆内存中开辟一块空间
举例:
Integer i =new Integer(9);
Integer j = new Integer(9);
i == j 这时返回的是false
三、从常量池取对象跟new出来的对象也是不同的
举例:
Integer i = 12;
Integer j = new Integer(12)
i == j 这时返回的是false