String类中的hashCode方法和equals方法
1.hashCode()
将字符串转换为char数组,然后根据算法h = 31 * h + val[i]计算得到一个int型数据,得到hashcode值,由此可见,hashcode值与字符串的内容有关
public int hashCode() {
int h = hash;
if (h == 0 && value.length > 0) {
char val[] = value;
for (int i = 0; i < value.length; i++) {
h = 31 * h + val[i];
}
hash = h;
}
return h;
}
2.equals()
在Object类中equals方法只用”==“比较两个对象的地址值(引用数据类型),地址相同才返回true;
public boolean equals(Object obj) {
return (this == obj);
}
String类重写了equals,可进一步判断不同对象的内容是否相同:首先判断当前String对象与待比较对象的地址值是否相同,地址相同说明为同一个对象,内容也一定相同,返回true;
其次需要先判断当前对象是否为String对象:否,返回false;是,将俩对象的值转换为char数组,依次比较数组中的值。
public boolean equals(Object anObject) {
if (this == anObject) {
return true;
}
if (anObject instanceof String) {
String anotherString = (String)anObject;
int n = value.length;
if (n == anotherString.value.length) {
char v1[] = value;
char v2[] = anotherString.value;
int i = 0;
while (n-- != 0) {
if (v1[i] != v2[i])
return false;
i++;
}
return true;
}
}
return false;
}
由以上分析可知,两对象equals比较为true,它们的hashcode一定相同;但两对象的hashcode相同,equals却不一定结果为true。