重写自定义类的equals方法和hashcode方法

从数据库里查出一条数据。
查询两次,分别是两个实体Bean。
例如:select * from user where id=1
查询两次(不用Hibernate的情况下)分别是两个User对象,
这时需要比较两个对象是否相等(其实是要比较里面的内容是否相等)
JVM在堆中分配了两块内存存储这两个对象
如果单纯的使用equals比较结果肯定为false
可以查看equals方法的源码会发现其实equals比较的也是内存地址

public boolean equals(Object obj) {
return (this == obj);
}

但是我们期望比较的是里面的值啊,也就是说我们期望的结果应该是true
对此,可以学String类一样重写Object类的equals()和hashcode()
给个重写User类的例子:

public class User {

private Integer id;
private String name;

public Integer getId() {
return id;
}

public void setId(Integer id) {
this.id = id;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

/**
* 重写equals方法 <br>
* obj为传入的与当前对象相比较的对象
*/
@Override
public boolean equals(Object obj) {
/*
* 判断传入的对象是否是当前类类型 如果不是则直接返回false
*/
if (obj instanceof User) {
User u = (User) obj;
return this.id.intValue() == u.getId().intValue();
}
return false;
}

/**
* 重写hashcode
*/
@Override
public int hashCode() {
// 这里可以写一个用来比较的实体属性
return this.id;
}
}


写一个main函数试一试

public static void main(String[] args) {
User u1 = new User();
u1.setId(1);
User u2 = new User();
u2.setId(1);
System.out.println(u1.equals(u2)); //打印结果为true
}



最后谈一下,为什么重写equals时也非得重写hashcode,如果去掉重写hashcode那段方法会发现打印结果也是为true。
我举例说明:在映射表或散列表中存储对象时,检查映射表中是否存在该对象的标准就是检查hashcode,同时散列表会根据对象的hashcode来确定该对象将要具体存储到哪个桶。。。。详情请咨询《数据结构》
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值