java中Set集合

概述:

  Set集合类似于一个罐子,程序可以依次把多个对象“丢进”Set集合,而Set集合通常不能记住元素的添加顺序。实际上Set就是Collection只是行为略有不同(Set不允许包含重复元素)。

 Set集合不允许包含相同的元素,如果试图把两个相同元素加入同一个Set集合中,则添加操作失败,add()方法返回false,且新元素不会被加入

HashSet类
HashSet是Set接口的典型实现,大多数时候使用Set集合时就是使用这个实现类。HashSet按Hash算法来存储集合中的元素,因此具有很好的存取和查找性能。底层数据结构是哈希表。
哈希表
一个元素为链表的数组,综合了数组与链表的优点。

HashSet具有以下特点:

    • 不能保证元素的排列顺序,顺序可能与添加顺序不同,顺序也可能发生变化;
    • HashSet不是同步的;
    • 集合元素值可以是null;
    • 没用索引

转载于:https://www.cnblogs.com/kun19/p/11144732.html

### JavaSet 集合概述 #### Set 接口特性 SetJava 集合框架中的一个重要接口,其主要特点是不允许存储重复元素[^2]。这使得 Set 类似于数学上的集合概念,在实际应用中非常有用。 #### 实现类及其特点 - **HashSet** - 基于哈希表实现,内部通常使用 `HashMap` 来管理数据[^1]。 - 提供常数时间复杂度 O(1) 的性能用于基本操作(add, remove 和 contains),假设哈希函数分配得当。 - **LinkedHashSet** - 继承自 HashSet 并保持插入顺序不变。 - 同样提供高效的存取速度,但在迭代访问时会按照元素被添加到集合中的先后次序返回。 - **TreeSet** - 底层基于红黑树实现,能够自动对元素进行排序。 - 支持自然排序或通过 Comparator 定制排序逻辑。 - 插入、删除和查找的时间复杂度均为 O(log n)。 #### 数据结构应用场景 对于不同类型的 Set 实现: - 当需要快速的成员测试而不在乎顺序时可以选择 `HashSet`. - 如果希望保留元素加入集合时的顺序,则应考虑使用 `LinkedHashSet`. - 对有序性的需求较高,比如要频繁获取最小/最大值的情况下推荐选用 `TreeSet`. #### 示例代码展示常见操作 下面给出一段简单的例子来说明如何创建 Sets 及执行一些基础的操作如求交集和差集: ```java import java.util.HashSet; import java.util.Set; public class Example { public static void main(String[] args) { // 创建两个整型的 HashSet Set<Integer> setA = new HashSet<>(); Set<Integer> setB = new HashSet<>(); // 添加元素至第一个集合 setA.add(1); setA.add(2); setA.add(3); // 添加元素至第二个集合 setB.add(2); setB.add(3); setB.add(4); // 计算 A ∩ B (即两者的公共部分) Set<Integer> intersection = new HashSet<>(setA); intersection.retainAll(setB); System.out.println("Intersection of sets is: " + intersection); // 计算 A - B (即只存在于前者而不属于后者的部分) Set<Integer> differenceAB = new HashSet<>(setA); differenceAB.removeAll(setB); System.out.println("Elements only in first set are: " + differenceAB); // 计算 B - A Set<Integer> differenceBA = new HashSet<>(setB); differenceBA.removeAll(setA); System.out.println("Elements only in second set are: " + differenceBA); } } ``` 这段程序展示了怎样利用 `retainAll()` 函数计算两个集合之间的交集,以及运用 `removeAll()` 方法找出差异项[^3].
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值