如果要想取消掉重复元素,则需要Object类中的两个方法
hashCode():表示唯一的编码
equals() ;进行对象的比较操作
import java.util.Set ; //导入Set接口
import java.util.HashSet ; //导入TreeSet类
class Person //定义Person类
{
private String name ;
private int age ;
public Person(String name,int age)
{
this.name = name ;
this.age = age ;
}
public boolean equals(Object obj) //覆写equals方法,完成对象比较
{
if(this==obj)
{
return true ;
}
if(!(obj instanceof Person))
{
return false ;
}
Person p = (Person)obj ; //向下转型
if(this.name.equals(p.name)&&this.age ==p.age)
{
return true ;
}
else
{
return false ;
}
}
public int hashCode()
{
return this.name.hashCode()*this.age ; //定义一个公式
}
public String toString()
{
return "姓名:"+this.name+";年龄:"+this.age ;
}
}
public class RepeatDemo01
{
public static void main(String[] args)
{
Set<Person> allSet = new HashSet<Person>() ; //实例化TreeSet对象
allSet.add(new Person("张三",20)) ; //向集合中插入多个Person对象
allSet.add(new Person("李四",21)) ; //向集合中出入Person对象
allSet.add(new Person("王五",12)) ; //向集合中插入Person对象
allSet.add(new Person("王五",12)) ; //向集合中插入Person对象
allSet.add(new Person("王五",23)) ; //向集合中插入Person对象
allSet.add(new Person("小六",12)) ; //向集合中插入Person对象
System.out.println("\n"+allSet) ;
}
}
一个好的类应该覆写Object类中的equals()方法,hashCode()方法,toString()方法 实际上在String中已经全部覆写完成了、