`

hashcode和equals方法

阅读更多
今天看1.6的JDK
找到String的hashCode方法,
引用
hashCode
public int hashCode()返回此字符串的哈希码。String 对象的哈希码根据以下公式计算:
s[0]*31^(n-1) + s[1]*31^(n-2) + ... + s[n-1]
使用 int 算法,这里 s[i] 是字符串的第 i 个字符,n 是字符串的长度,^ 表示求幂。(空字符串的哈希值为 0。)

覆盖:
类 Object 中的 hashCode
返回:
此对象的哈希码值。
另请参见:
Object.equals(java.lang.Object), Hashtable

然后看了一个源码:
   
public int hashCode() {
	int h = hash;
        int len = count;
	if (h == 0 && len > 0) {
	    int off = offset;
	    char val[] = value;

            for (int i = 0; i < len; i++) {
                h = 31*h + val[off++];
            }
            hash = h;
        }
        return h;
 }


哈哈,展开发现是一个递归函数哦.
我用字符串"123"作测试:
用JDK的方法:49*31^2+50*31+51;
用Source里的方法:(31*49+50)*31+51;
于是得到48690,在java中写了一行代码测试,验证结果正确:
System.out.println("123".hashCode());

结果:
引用
48690

再来看equals方法:
public boolean equals(Object anObject) {
	if (this == anObject) {
	    return true;
	}
	if (anObject instanceof String) {
	    String anotherString = (String)anObject;
	    int n = count;
	    if (n == anotherString.count) {
		char v1[] = value;
		char v2[] = anotherString.value;
		int i = offset;
		int j = anotherString.offset;
		while (n-- != 0) {
		    if (v1[i++] != v2[j++])
			return false;
		}
		return true;
	    }
	}
	return false;
    }

我贴这段代码,不仅是要告诉自己如果明白String的equals方法,也要学习如何自己重写hashcode和equals方法.
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics