关于集合中理解的问题

package com.isannian.java;

import java.util.HashSet;

public class SetTest
{
	  public static void main(String[] args)
	{
		HashSet set=new HashSet();
	
//		System.out.println(set.add("a"));
//		set.add("b");
//		set.add("c");
//		System.out.println(set.add("a"));
//		System.out.println(set);	
		
		set.add(new RenLei("zhangsan"));
//		set.add(new RenLei("lisi"));
//		System.out.println(set);

//		RenLei ren=new RenLei("zhangsan");
//		set.add(ren);
//		set.add(ren);
//		System.out.println(set);
//		
//		String s1 =new String("lisi");
//		String s2 =new String("lisi");
//		System.out.println("hashcode :"+(s1.hashCode()==s2.hashCode()));
//		set.add(s1);
//		set.add(s2);
//		System.out.println(set);
		
		RenLei r1 =new RenLei("a");
		RenLei r2 =new RenLei("a");
		System.out.println("hashcode :"+(r1.hashCode()==r2.hashCode()));
		System.out.println("equals: "+ r1.equals(r2));
		
		set.add(r1);
		set.add(r2);
		System.out.println(set);
	}

}
 class RenLei{
	  
	 String name;

	public RenLei(String name){
		 this.name =name;	 
	 }

//	@Override
//	public int hashCode()
//	{
//		final int prime = 31;
//		int result = 1;
//		result = prime * result + ((name == null) ? 0 : name.hashCode());
//		return result;
//	}
//
//	@Override
//	public boolean equals(Object obj)
//	{
//		if (this == obj)
//			return true;
//		if (obj == null)
//			return false;
//		if (getClass() != obj.getClass())
//			return false;
//		RenLei other = (RenLei) obj;
//		if (name == null)
//		{
//			if (other.name != null)
//				return false;
//		} else if (!name.equals(other.name))
//			return false;
//		return true;
//	}
	
	@Override
	public int hashCode()
	{
		// TODO Auto-generated method stub
		return this.name.hashCode();
	}

 
	@Override
	public boolean equals(Object obj)
	{
		if(this == obj){
			return true;	
		}
		if(null != obj && obj instanceof RenLei)
		{
			RenLei r=(RenLei) obj;
			if(name.equals(r.name))//obj.equals(r.name)
			{
				return true;
			}
		}
		return false;

	}

}

set 集合中(接口)

当使用 HashSet 时,使用add方法时,对象会自动调用hashCode() 方法,判断 已经存储在集合中的对象的hash code值是否与增加对象的hash code 值一致;如果不一致,直接加进去;

如果 一致, 在进行 equals方法比较,equals方法如果返回true,表示对象已经加进去了,就不会再添加新的 对象! 

否则加进去!


如果重写 Object 中的 equals  方法  ,那么也要重写 hashCode 方法,反之亦然!






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值