Java Object的hashCode()和equals()简单分析

来源:互联网 发布:马加爵事件真相 知乎 编辑:程序博客网 时间:2024/05/17 19:14
package cn.iworker.collection;import java.util.HashSet;/* * 关于object的equals方法的特点: * 1.reflexive自反性:x.equals(x)为 true; * 2.symmetric对称性:x.equals(y)为true 那么 y.equals(x)也为true; * 3.transitive传递性:x.equals(y)true,y.equals(z)true--->>x.equals(z)true; * 4.一致性consistent:x.equals(y)的第一次调用为ture,那么x.equals(y)的第二次,第三次,第N次调用也应该为true,前提条件是x,y的值不改变。 * 5.对于非空引用x,x.equals(null)返回false. * 关于object的hashCode方法的特点: * 1.在java应用的一次执行过程中,对于同一个对象的hashcode方法的多次调用,他们应该返回同样的值(前提是该对象的信息没有发生变化)。 * 2.对于两个对象来说。如果使用equals方法比较返回ture,那么这两个对象的hashcode值一定是相同的。 * 3.对于两个对象来说,如果使用equals方法比较返回false,那么这两个对象的hashcode值不要求一定不同(可以相同,可以不同)但是不同可以提高应用的性能。 * 4.对于Object类来说,不同的Object对象的HashCode值是不同的(Object类的hashCode值表示的是一个地址); *  */public class HashCodeTest {/** * @desc <pre> * 1.当使用HashSet时,hashCode()方法就会得到调用,判断已经存储在集合中的对象的hashCode值是否与增加的对象的hashCode值一致: * 如果不一致,直接加进去,如果一致,再进行equals方法比较,如果equals方法如果返回true,表示对象已经加进去了, * 2.如果重写了equals方法,也要重写hashCode方法。反之亦然 * </pre> * @author Weiliang Hu * @date 2013-10-24 * @param args */public static void main(String[] args) {HashSet<Object> mHashSet = new HashSet<Object>();String a = new String("a");String b = new String("a");System.out.println("hashCode:" + (a.hashCode() == b.hashCode()));// hashCode:true        Person1 person1=new Person1("zhangsan");        Person1 person2=new Person1("zhangsan");        mHashSet.add(person2);        mHashSet.add(person1);        System.out.println(mHashSet);//OK输出一个地址:[cn.iworker.collection.Person1@aa9c3074]}}class Person1{String name;public Person1(String name){this.name=name;}public int hashCode(){return this.name.hashCode();}@Overridepublic boolean equals(Object obj) {if(this==obj){   return true;}if((null != obj)&&obj instanceof Person1){     Person1 person=(Person1) obj;     if(name.equals(person.name)){     return true;     }}return false;}}

原创粉丝点击