set去除重复对象

来源:互联网 发布:jdbc mysql的url 编辑:程序博客网 时间:2024/06/05 22:12
package setproject;
public class Person {
private String userName;
private String password;
private String address;

public Person(){}
public Person(String userName,String password,String address){
    this.userName=userName;
    this.password=password;
    this.address=address;
}

@Override  
public boolean equals(Object obj) {  
    if(obj == null) return false;  
    if(this == obj) return true;  
    if(obj instanceof Person){   
        Person message =(Person)obj;
        // 比较userName,password,address 一致时才返回true,之后再去比较 hashCode  
        if(message.userName == this.userName
           && message.password.equals(this.password)
           &&message.address.equals(this.address)) return true;  
        }  
          return false;  
 }  

@Override  
public int hashCode() {  
//重写hashcode 方法,返回的hashCode 不一样才认定为不同的对象
//return id.hashCode(); // 只比较id,id一样就不添加进集合  
    return userName.hashCode() * password.hashCode()*address.hashCode();  
   }

}


测试用例如下:


public class SetDemo {
    @Test
    public void testDemo(){
        Set<Person> setPerson=new HashSet<Person>();
        setPerson.add(new Person("李白","123","济南"));
        setPerson.add(new Person("李清照","456","山海关"));
        setPerson.add(new Person("李商隐","123","嘉峪关"));
        setPerson.add(new Person("李白","123","济南"));
        setPerson.add(new Person("李白","456","济南"));
        for(Iterator<Person> iter=setPerson.iterator();iter.hasNext();){
            Person person =iter.next();
            System.out.println("username:"+person.getUserName()+",password:"+person.getPassword()+",address:"+person.getAddress());
        }
    }
}


输出的值如下:

"李白","123","济南"

"李清照","456","山海关"

"李商隐","123","嘉峪关"

"李白","456","济南"



原创粉丝点击