关于联合主键
联合主键为什么要重写equals方法和hashCode方法,是为了保证唯一性
1、在数据库保证唯一性是使用的联合主键
2、把一系列的对象放到内存的时候,为了区分同名对象,数据库是使用联合主键来区分,内存中也是用相应的方式来区分,所以重写equals和hashCode方法,而且,逻辑不能乱写,hashCode不能使用父类里面的,否则两个同样的对象就视为同一对象,在equals方法中,从内存的角度讲, 只有联合主键中的每一个都相同,才叫相同,才应该返回true
@Override
public boolean equals(Object o) {
if(o instanceof StudentPK) {//判断是否是此对象
StudentPK pk = (StudentPK)o;//强制转换
if(this.id == pk.getId() && this.name.equals(pk.getName())) {
return true;//实现了和数据库判断一致
}
}
return false;
}
当内容要放进hash表里面的时候,首先判断hash码是否相同,如果相同,则放在同一位置,每个位置往往装的是一个链表,链表上每个对象都是hash码相同的对象,所以在查找hash表的时候直接找到hash码对应的位置,然后进行equals方法进行判断,
@Override
public int hashCode() {
return this.name.hashCode();
}
所以,总结,当很多对象被放进hash表的时候,相同的hash码的对象放在同一个位置,查找的时候先找到对应的位置的链表,然后进行equals,找到对应的对象
联合主键为什么要重写equals方法和hashCode方法,是为了保证唯一性
1、在数据库保证唯一性是使用的联合主键
2、把一系列的对象放到内存的时候,为了区分同名对象,数据库是使用联合主键来区分,内存中也是用相应的方式来区分,所以重写equals和hashCode方法,而且,逻辑不能乱写,hashCode不能使用父类里面的,否则两个同样的对象就视为同一对象,在equals方法中,从内存的角度讲, 只有联合主键中的每一个都相同,才叫相同,才应该返回true
@Override
public boolean equals(Object o) {
if(o instanceof StudentPK) {//判断是否是此对象
StudentPK pk = (StudentPK)o;//强制转换
if(this.id == pk.getId() && this.name.equals(pk.getName())) {
return true;//实现了和数据库判断一致
}
}
return false;
}
当内容要放进hash表里面的时候,首先判断hash码是否相同,如果相同,则放在同一位置,每个位置往往装的是一个链表,链表上每个对象都是hash码相同的对象,所以在查找hash表的时候直接找到hash码对应的位置,然后进行equals方法进行判断,
@Override
public int hashCode() {
return this.name.hashCode();
}
所以,总结,当很多对象被放进hash表的时候,相同的hash码的对象放在同一个位置,查找的时候先找到对应的位置的链表,然后进行equals,找到对应的对象