【java编程】Collection类之HashSet存储自定义对象元素

/*SET集合是无序的,判断无序的方法是先比较hashcode值,如果相同
  再比较equals方法*/
import java.util.*;
class hashCodeDemo
{
	public static void main(String[] args) 
	{
		HashSet hs = new HashSet();
		hs.add(new Person("lisi",33));
		hs.add(new Person("lisi",34));
		hs.add(new Person("lisi",35));
		hs.add(new Person("lisi",35));
		hs.add(new Person("lisi",36));
		hs.add(new Person("lisi",36));		
		Iterator it = hs.iterator();
		while(it.hasNext())
		{
			//因为ArrayList里面添加对象时都被强制转换成Object类型
			Person p=(Person)it.next();
			System.out.println(p.getName()+"::"+p.getAge());
		}
	}

}
class Person
{
	private String name;
	private int age;
	Person(String name,int age)
	{
		this.name=name;
		this.age=age;
	}
	public String getName()
	{
		return this.name;
	}
	public int getAge()
	{
		return this.age;
	}
	//复写equals方法
	public boolean equals(Object obj)
	{
		Person p = (Person)obj;
		System.out.println(this.name+"......equals......"+p.getName());
		return this.name.equals(p.getName()) && this.age==p.getAge();
	}
	//复写hashCode方法
	public int hashCode()
	{
		System.out.println(this.name+"......hashCode");
		return name.hashCode()+age*39;
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值