? ? ? ? ==在比较基本类型的时候比较的是内容
? ? ? ? 例如:
int a=1;
int b=1;
System.out.println(a==b);//返回值为true
? ? ? ? 比较引用类型时比较的是地址(比较包装类时比较的也是地址)
? ? ? ? 例如:
Integer i1 = 100;
Integer i2 = 100;
System.out.println(i1 == i2);//返回值为true
Integer i3 = 200;
Integer i4 = 200;
System.out.println(i3 =[= i4);//返回值为false
? ? ? ? ? ?为什么上方两个例子同样是比较引用类型Integer包装类,==号比较的不是地址吗,为什么第一个会相同,不应该是不同吗?
? ? ? ? 因为?官方认定,-128至127是包装类型中最常用的256个数字,所以在方法区中设立了整数缓冲区存放这些数字,当使用的数字在此区间之内,将不会开辟堆空间,使用缓冲区中的内容,目的为减少空间浪费,节约空间资源
? ? ? ? ?所以只要是整数缓冲区的数字,就相当于在整数缓冲区开辟了相同的空间,所以==号比较两个引用的地址相同,返回值为true。
? ? ? ? 如果是创建包装类是new了对象,那么==号比较两个包装类必不相等(逢new必开辟新空间)
Integer i5 = new Integer(127);
Integer i6 = new Integer(127);
System.out.println(i5 == i6);//false
Integer i7 = 127;
System.out.println(i5 == i7);//false
? ? ? ? (1)equals()比较基本类型时比较的也是内容,所以一般比较基本类型时用==号就可以了
? ? ? ? (2)在equals()方法没有进行重写时比较引用类型时比较的也是引用的地址
? ? ? ? (3)而equals()在经过人为重写后比较的就是内容了
? ? ??
? ? ? ? ? ? ?boolean(返回值类型) equals(Object o):判断当前对象与参数对象是否相同
?????????????重写原因:该方法默认比较地址。 但是实际开发中,某些场景下需要比较内容,所以需要重写
?????????????重写规则:? ? ? ? ? ?? ?
public boolean equals(Object o){
? ? ? ?//自反性
? ? ? ?if (this == o) {
? ? ? ? ? ?return true;//自己和自己比,一定相同
? ? ? }
? ? ? ?//类型判断+非空判断
? ? ? ?if (this.getClass() != o.getClass() || o == null) {
? ? ? ? ? ?return false;//实际对象类型不同或参数为null,一定不同
? ? ? }
? ? ? ?//类型强转
? ? ? ?当前类名 引用名 = (当前类名) o;
? ? ? ?//属性值比较
? ? ? ?//基本类型比较值:==
? ? ? ?//引用类型比较值:对象1.equals(对象2)
? ? ? ?return this对象的属性值与引用名的属性值比较的结果;
? }
类库中的引用类:已经重写,直接调用
自定义的引用类:自行重写equals
????????
?