基本数据类型和包装类型有自动装箱拆箱机制,因此有一个定律可以使用:
取值范围在-128~127。并且两个引用都是包装类型,创建方式至少有一个是用new,那么两者就不相等,否则两者相等。
有一个点需要注意,基本数据类型里面浮点型是没有实现常量池的。
注意char后面是字符还是ASCII码,ASCII常量池范围是0~127。
原因:
- 首先是自动装箱拆箱机制(这个是针对两个引用类型不同的情况),是在比较的时候,如果一个引用是基础类型,一个是包装类型,会将包装类型转成基本类型再进行比较;因此是比较值,无论值是多少都相等。
- 如果引用是包装类型,使用直接赋值,并且范围在-128~127,那么包装类型会直接指向常量池的对象。比较的就是引用地址,两个都指向常量池的话,两者地址相等,因此相等。(超过常量池范围对象就不在常量池了,而是在堆,两个不同的对象,因此两个地址就不一样)
- 如果两个引用都是包装类型,赋值至少有一个是使用new,那么要么一个指向常量池,一个指向堆;或者两个都是指向堆的不同对象,因此都是比较地址,不相等。
int
int整型在进行比较的时候,首先取值范围在-128~127之间。只要两个引用都是包装类型,并且至少一个是用new Integer()创建对象就会出现不等的情况
Integer a=new Integer(1);
Integer b=new Integer(1);
System.out.println(a==b);//false
Integer b=new Integer(1);
Integer a=1;
System.out.println(a==b);//false
Integer a=1;
Integer b=1;
System.out.println(a==b);//true
int a=new Integer(1);
Integer b=new Integer(1);
System.out.println(a==b);//true
int a=new Integer(1);
Integer b=1;
System.out.println(a==b);//true
Integer a=129;
int b=129;
System.out.println(a==b);//true
Integer a=129;
Integer b=129;
System.out.println(a==b);//false
char
//char和int差不多,不过需要注意使用字符和ASCII码的情况
Character a='1';
Character b=new Character('1');
System.out.println(a==b);//false
Character a=new Character('1');
Character b=new Character('1');
System.out.println(a==b);//false
Character a=128;
Character b=128;
System.out.println(a==b);//false
char a=new Character('1');
char b=new Character('1');
System.out.println(a==b);//true
Character a=new Character('1');
char b=new Character('1');
System.out.println(a==b);//true
Character a='1';
Character b='1';
System.out.println(a==b);//true
Character a='1';
char b=new Character('1');
System.out.println(a==b);//true
其他的类型进行类推就可以了,上面的原因才是理解的关键。