java中重写equals方法

本文探讨了Java中equals方法与运算符==的区别,重点解释了它们在基本类型与引用类型中的不同表现,并通过示例代码说明如何正确使用equals方法进行对象比较。

在写java的时候难免会碰到等值问题,java中默认情况下,equals方法与 ‘==’ 是等价的,列入:

char a='d'  ;

char b='d' ;

if(a==b) System.out.println("量值相等");          运行时,程序可以正常输出,但是如下时:

String a=new String("asg");

String b=new String("asg");

if(a==b) System.out.println("量值相等");        运行时,程序就会报错。

String a="asg";

String b="asg";

if(a==b) System.out.println("量值相等");      运行时,程序正常。(该变量比较在栈中比较,栈中找到了两个变量的值,所以运行正常。而new出来的对象在堆中。上面错误)

那么,上面的具体情况又是什么?

因为String属于引用类型,而char属于基本类型,在Java中,基本数据类型(java基本数据类型包含:byte,short,int,long    float,double  boolean  和 char)是可以直接用‘==’做比较的,变量类型在栈中创建。但是引用类型,不能直接用‘==’,因为引用类型用‘==’的时候,对象在堆中创建,都会视为内存地址的比较。而在新建的引用类型对象时,new出来的对象地址并不相同,所以必须用equals。而equals的默认方法却是与‘==’等价的,那么我们就要重写这个方法。如下:

public boolean equals(object  otherobject){

if(this == otherobject)  return true;

if(otherobject instanceof String){

String otherString = (String) otherobject;

int n=count;//count:参数指定数组的长度

if(n==othertString.count){

char a[]=value;//value:字符源数组

char b[]=otherString.value;

int i=offset;//offset参数是子数组第一个字符的索引,一般默认为0

while(n--!=0){

if(a[i++] != b[i++]) {

return false;

}

return true;

}

}

return false;

}

}

Java 中,当需要比较对象的内容而非引用时,通常要重写 `equals` 方法 `hashCode` 方法。 若要比较两个对象是否相等,需重写 `equals` 方法。以 `PersonWithOverride` 类为例,该类有 `private int age` `private String name` 两个属性,要比较两个 `PersonWithOverride` 类生成的对象是否相等,就要重写 `equals` 方法。而使用 Eclipse 自动生成 `equals` 方法时,如使用 `username` `password` 字段生成的 `equals` 方法示例如下: ```java @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; User other = (User) obj; if (password == null) { if (other.password != null) return false; } else if (!password.equals(other.password)) return false; if (userName == null) { if (other.userName != null) return false; } else if (!userName.equals(other.userName)) return false; return true; } ``` 同时,当重写 `equals` 方法时,必须重写 `hashCode` 方法,以维护 `hashCode` 方法的常规协定,该协定声明相等对象必须具有相等的哈希码。例如,当 `obj1.equals(obj2)` 为 `true` 时,`obj1.hashCode() == obj2.hashCode()` 必须为 `true`;当 `obj1.hashCode() == obj2.hashCode()` 为 `false` 时,`obj1.equals(obj2)` 必须为 `false`。若不重写 `hashCode` 方法,在存储散列集合(如 `Set` 类)时,可能会存储两个值一样的对象,导致混淆。 重写时需注意:尽量保证使用对象的同一个属性来生成 `hashCode()` `equals()` 两个方法;`equals` 方法必须保证一致(如果对象没有被修改,`equals` 应该返回相同的值);任何时候只要 `a.equals(b)`,那么 `a.hashCode()` 必须 `b.hashCode()` 相等,两者必须同时重写。当使用 ORM 时,要确保在 `hashCode()` `equals()` 对象中使用 `getter` `setter` 而不是直接引用成员变量,因为在 ORM 中有的时候成员变量会被延时加载,这些变量只有当 `getter` 方法被调用的时候才真正可用[^2][^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值