中不二 2015-04-15 06:33 采纳率: 0%
浏览 1887

下面是list类hashcode方法内容,知道为什么hashcode要那么计算吗?

hashCode = 1;
Iterator i = list.iterator();
while (i.hasNext()) {
Object obj = i.next();
hashCode = 31*hashCode + (obj==null ? 0 : obj.hashCode());
}

  • 写回答

1条回答 默认 最新

  • threenewbee 2015-04-15 06:36
    关注

    hashcode的算法不唯一,只要保证,相同的变量(equals返回true),hashcode肯定相等,不同的变量,可以相等,可以不等,但是尽量不等,这两个条件就可以了。
    乘以31再加上后一位的hash,这个的目的就是尽量不等。

    评论

报告相同问题?

悬赏问题

  • ¥15 安装svn网络有问题怎么办
  • ¥15 Python爬取指定微博话题下的内容,保存为txt
  • ¥15 vue2登录调用后端接口如何实现
  • ¥65 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥15 latex怎么处理论文引理引用参考文献