hashCode = 1;
Iterator i = list.iterator();
while (i.hasNext()) {
Object obj = i.next();
hashCode = 31*hashCode + (obj==null ? 0 : obj.hashCode());
}
hashcode的算法不唯一,只要保证,相同的变量(equals返回true),hashcode肯定相等,不同的变量,可以相等,可以不等,但是尽量不等,这两个条件就可以了。
乘以31再加上后一位的hash,这个的目的就是尽量不等。