HashSet集合和LinkedHashSet集合

Set集合有多个子类,其中包 java.util.HashSet、java.util.LinkedHashSet 这两个集合类。

HashSet集合 

 java.util.HashSet 继承自java.util.AbstractSet,是 Set 接口的一个实现类,它所存储的元素是不可重复的,并且元素都是无序的(即存取顺序不一致)。 java.util.HashSet 底层的实现其实是一个 java.util.HashMap 支持。

HashSet 是根据对象的哈希码来确定元素在集合中的存储位置(即内存地址),因此具有良好的存取和查找性能。保证元素唯一性 的方式依赖于: hashCode 与 equals 方法。在比较两个加入哈希集合HashSet中的元素是否相同时,会先比较哈希码方法hashCode()的返回值是否相同,若相同则再使用equals()方法比较其存储位置(即内存地址),若两者都相同则视为相同的元素。

之所以在比较了哈希码之后,还要通过equals()方法进行比较,是因为对不同元素计算出的哈希码可能相同。因此,对于哈希集合来说,若重写了元素对应类的hashcode()方法或equals()方法中的某一个,则必须重写另一个,以保证其判断的一致性。

public class HashSetDemo {
	public static void main(String[] args) {
		//创建Set集合并指定为Integer类型
		HashSet<Integer> set = new HashSet<Integer>();
		//添加元素
		set.add(1);
		set.add(2);
		set.add(3);
		set.add(2);
		//增强for遍历
		for(Integer i : set) {
			System.out.println(i);
		}
	}
}

输出结果:

1

2

3

注:根据结果我们发现字符串‘2’只存储了一个,也就是说重复的元素set集合不存储。 输出输出哈希集合元素时不一定是按元素的存储顺序输出,因为哈希集合中的元素是没有特定顺序的,若一定要让元素有序输出,则需要使用LinkedHashSet类。

LinkedHashSet集合

java.util.LinkedHashSet继承自java.util.HashSet,它是链表和哈希表组合的一个数据存储结构。
它不仅保证元素的唯一性,并且可以保证元素的有序性。

public class LinkedHashSetDemo {
	public static void main(String[] args) {
		//创建Set集合并指定为String类型
		Set<String> set = new LinkedHashSet<String>();
		//添加元素
		set.add("aaa");
		set.add("bbb");
		set.add("ccc");
		set.add("ccc");
		//迭代器遍历
		Iterator<String> it = set.iterator();
		while(it.hasNext()) {
			System.out.println(it.next());
		}
	}
}

输出结果:

aaa

bbb

ccc

注:该结果是顺序输出。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值