import java.util.*;
import java.util.Iterator;
import java.util.Set;
//一般使用容器,自定义类都需要重写toString方法,若是hashtable,hashSet hashMap还要重写equals和hashCode方法!(且记)
class Person{
private int ID;
private String name;
public Person(int ID,String name)
{
this.ID=ID;
this.name=name;
}
public String toString()//toString的方法重写
{
return ID+" "+name;
}
public boolean equals(Object o)//对equals的方法重写,参数为一个父类的对象
{
Person p=(Person)o;//将父类的对象转换为子类的对象,调用子类特有的属性和方法
return this.ID==p.ID&&this.name==p.name;//若当前对象的ID和name和接受对象的ID和name相等则返回true,否则返回fales
}
public int hashCode()//对hashCode方法的重写,因为类里面的基本属性的equals都重写过,所以他们的hashCode的方法也重写过
{
return ID*this.name.hashCode();//这里若相等则返回一样的hashCode
}
}
//遍历所有Collection接口的实现方法
public class Test2{
public static void showCollection(Collection c)
{
Iterator it=c.iterator();
while(it.hasNext())
{
System.out.println(it.next());
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
//HashSet<Person>set=new HashSet<Person>();
Set s=new HashSet();
//因为set里面的quals方法和hashCode方法都被重写,而且一般自定义的类都需要重写,所以重复的无法放到set的中
s.add(new Person(1,"小刚"));
s.add(new Person(2,"小成"));
s.add(new Person(2,"小成"));
s.add(new Person(3,"小华"));
s.add(new Person(3,"小华"));
s.add(new Person(3,"小华"));
showCollection(s);//遍历Collection接口中的元素方法
}
}
这里就是简单实现了一下HahSet,等实现完HashMap后,会对HashSet HashMap做一个具体的总结
Java一步一脚印—HashSet
最新推荐文章于 2024-08-13 22:39:05 发布