黑马程序员技术交流社区
标题:
Java中String的哈希值计算
[打印本页]
作者:
liuzhipeng
时间:
2015-12-9 09:13
标题:
Java中String的哈希值计算
下面都是从String类的源码中粘贴出来的
复制代码
1 private int hash; // Default to 0
2 public int hashCode() {
3 int h = hash;
4 if (h == 0 && value.length > 0) {
5 char val[] = value;
6 for (int i = 0; i < value.length; i++) {
7 h = 31 * h + val[i];
8 }
9 hash = h;
10 }
11 return h;
12 }
复制代码
下面利用上述方法计算字符串”Lee”的哈希值
‘L’的ASCII码为76,’e’的ASCII码为101
for循环3次
h=31*0+76=76
h=31*76+101=2457
h=31*2457+101=76268
所以字符串”Lee”的哈希码就是76268
作者:
迷茫不堪的年纪
时间:
2015-12-9 11:09
相当于看到了 HashSet的重写
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2