今天学到java的关于集合框架的最后面。。讲到哈希这边。。。有个程序。有个小地方没听明白
下面是代码
class Person
{
private String name;
private int age;
Person(String name,int age)
{
this.name=name;
this.age=age;
}
public String getName()
{
return name;
}
public int getAge()
{
return age;
}
//没搞明白为什么加一个这个就能把相同的挑出来呢?
public int hashCode()
{
return 199;
}
public boolean equals(Object obj)
{
if(!(obj instanceof Person) )
return false;
Person p=(Person)obj;
return this.name.equals(p.name)&& this.age==p.age;
}
}
class HashSetDemo
{
public static void sop(Object obj)
{
System.out.println(obj);
}
public static void main(String[] args)
{
HashSet hs=new HashSet();
hs.add(new Person("a1",11));
hs.add(new Person("a2",14));
hs.add(new Person("a3",12));
hs.add(new Person("a3",12));
hs.add(new Person("a4",10));
Iterator it=hs.iterator();
while(it.hasNext())
{
Person p=(Person)it.next();
sop(p.getName()+"::"+p.getAge());
}
}
}
这边为什么加了这个
public int hashCode()
{
return 199;
}
他就能把重复的去掉呢?
没听明白。。。。。郁闷呢 |