1、java 中【基本类型】 和 【基本类型】的比较 == 比较的是值
2、java中【基本类型】 和 【引用类型】 的比较编译后也都是基本类型和基本类型的比较。
long
j=
10000l
;
Long i=
new
Long(
10000
)
;
System.
out
.println(i==j)
;
//true
所以引用类型和基本类型比较,编译成底层指令时,把引用类型转成了基本类型,再比较的值。
System.
out
.println(k.equals(j))
;
//true
引用类型的
java中所有类都继承于Object,如果没有重写Object的 equal方法,那么,引用类型
间的“==” 和 equal 都是比较的对象地址。
对于String ,基本类型的包装类型Boolean、Character、Byte、Shot、Integer、Long、Float、Double,适用1即==表比较地址,equal表示比较内容
StringBuffer 和StringBuilder特殊,==和equal都是比较地址,因为没有重写Object的equal方法。
3、java中【引用类型】和【引用类型】的比较
由于java 的 享元模式 缓存了 -128 ~ 127 的值
返回的不是一个新new出来的Integer对象,而是一个已经缓存在堆 中的对象
,所以对于下面两种声明方式就是去缓存在堆中的对象里取的,所指向的地址一样:不会重新创建对象。
Long m=
Long.valueof(127);
Long n=
127;
Long mk=
128L;
Long nk=
128L;
所以m 和 n 不管是equal 和 == 比较都是相等的(限制范围 -128~127)
System.
out
.println(m==n)
;
//true
System.
out
.println(m.equal(kn)
;
//true
System.
out
.println(mk==nk)
;
//false
System.
out
.println(mk.equal(nk))
;
//true
但是对于new 的新对象,还是会在java堆里面重新分配,所以和上面比较还是不等的;
Long m2=new Long(
127);
Long n2=new Long(
127);
System.
out
.println(m2==n2)
;
//false
System.
out
.println(m2.equals(n2))
;
//true