hashcode()的重写

来源:互联网 发布:java求最大值 编辑:程序博客网 时间:2024/06/04 16:26

今天去哪儿面试去水了一把,问到一个之前没想到的问题,让我重写hashcode()。之前没想过这个问题,都是直接调用,回来百度了一下,有点启发。


java规范建议同一个类的equals()方法和hashcode()方法应该是对应的,如果两个对象的equals()返回值相等,hashcode()返回值也相等。(当然,不一样不会报错)


hashcode()计算过程中最好用到每个有意义字段的散列码。特别的是:不能有随机数,因为同一个对象的hashcode()就可能不一样(笔者当时傻了,加了一个Random随机数,直接让面试官鄙视了。。。)


public class Person {private int age;private String name;......public int hashcode(){int code = 17;code = code * 37 + name.hashCode();code = code * 37 + age;return code;}}


0 0
原创粉丝点击