LinkedHashSet能保证元素唯一且按插入顺序排列,因其基于哈希表和双向链表实现,适合去重并保留添加顺序的场景。
在Java中,LinkedHashSet 是一个非常实用的集合类,它结合了 HashSet 的唯一性特点和 链表 维护插入顺序的能力。如果你希望存储不重复的元素,同时又想保留它们被添加的顺序,LinkedHashSet 是理想选择。
Java 提供了多种 Set 实现,但只有 LinkedHashSet 能在保证元素唯一的同时,保持插入顺序。以下是它的核心优势:
使用方式与普通 Set 类似,只需注意初始化类型为 LinkedHashSet 即可。
示例代码:
import java.util.*;
public class LinkedHashSetExample {
public static void main(String[] args) {
Set linkedHashSet = new LinkedHashSet<>();
linkedHashSet.add("Apple");
linkedHashSet.add("Banana");
linkedHashSet.add("Orange");
linkedHashSet.add("Apple"); // 重复元素,不会被添加
// 输出顺序与插入顺序一致
for (String fruit : linkedHashSet) {
System.out.println(fruit);
}
}
}
输出结果:
Apple Banana Orange
可以看到,尽管 Apple 被添加了两次,但只保留一次,并且所有元素按照添加顺序输出。
理解不同 Set 实现的行为差异有助于正
确选择:
以下情况推荐使用 LinkedHashSet:
注意:虽然 LinkedHashSet 保持插入顺序,但它不是线程安全的。多线程环境下需自行同步,或使用 Collections.synchronizedSet 包装。
基本上就这些。LinkedHashSet 在需要“去重 + 有序”的场景下表现优异,用法简单,开销合理,是开发中值得掌握的小技巧。