码迷,mamicode.com
首页 > 编程语言 > 详细

Java中的哈希值

时间:2015-11-26 19:03:46      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:

下面都是从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

  1. h=31*0+76=76
  2. h=31*76+101=2457
  3. h=31*2457+101=76268

所以字符串”Lee”的哈希码就是76268

Java中的哈希值

标签:

原文地址:http://www.cnblogs.com/youilika/p/4998402.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!