码迷,mamicode.com
首页 > 编程语言 > 详细

java 集合框架-HashSet

时间:2016-05-12 17:38:57      阅读:189      评论:0      收藏:0      [点我收藏+]

标签:

/*
利用HashSet来存储自定义元素

HashSet集合保证元素唯一性的依据:
是通过两个方法,hashCode和equals来完成。
如果元素的HashCode值相同,才会判断equals是否为true。
如果元素的HashCode值不同,不会调用equals。

这两个方法都是HashSet调用的,并没有显式调用。

注意:对于判断元素是否存在,以及删除等操作,依赖的方法是元素的hashcode和equals方法。
*/

import java.util.*;

class Person
{
	private String name;
	private int age;

	Person(String name,int age)
	{
		this.name=name;
		this.age=age;
	}

	public String getName()
	{
		return name;
	}

	public int getAge()
	{
		return age;
	}

	public int hashCode()
	{
		return name.hashCode()+age*37;
	}

	public boolean equals(Object obj)
	{
		if(!(obj instanceof Person))
			return false;
		Person p=(Person)obj;
		return this.name.equals(p.name)&&this.age==p.age;
	}

}

class HashSetDemo1 
{
	public static void main(String[] args) 
	{

		HashSet hs=new HashSet();
		hs.add(new Person("Lily_1",30));
		hs.add(new Person("Lily_2",30));
		hs.add(new Person("Lily_3",30));
		hs.add(new Person("Lily_3",30));
		hs.add(new Person("Lily_4",30));
		hs.add(new Person("Lily_4",30));
		hs.add(new Person("Lily_5",30));


		hs.remove(new Person("Lily_5",30));
		Iterator it=hs.iterator();

		while(it.hasNext())
		{
			Person p=(Person)it.next();
			sop(p.getName()+"..."+p.getAge());
		}
		System.out.println("Hello World!");
	}

	public static void sop(Object obj)
	{
		System.out.println(obj);
	}

}


Set:元素是无序(存入和取出的顺序不一定一致),元素不可以重复。

HashSet是基于哈希表的。
哈希表的特点:
哈希表中存的是对象的哈希地址值,当添加新的对象地址时,
首先判断哈希表中有没有该地址值,
若有,则判断是否为同一对象,不是的话则存储,是的话则不存了。
若没有,则存储。

这个特点决定了HashSet集合是无序的,不可重复的。

java 集合框架-HashSet

标签:

原文地址:http://blog.csdn.net/iemdm1110/article/details/51361729

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!