Java集合框架学习(四) LinkedHashSet详解
LinkedHashSet介绍
前面我们介绍了HashSet和TreeSet。
LinkedHashSet也是Set接口的一个实现类,同时还继承了HashSet
public class LinkedHashSet<E>extends HashSet<E>
implements Set<E>, Cloneable, Serializable
它和HashSet,TreeSet类似,以下是其特点:
1. LinkedHashSet是具有可预知迭代顺序的Set接口的哈希表和链接列表实现。
此实现与HashSet的不同之处在于,后者维护着一个运行于所有条目的双重链接列表。
此链接列表定义了迭代顺序,该迭代顺序可为插入顺序或是访问顺序。
2. LinkedHashSet底层使用LinkedHashMap来保存所有元素,它继承与HashSet,其所有的方法操作上又与HashSet相同。
3. LinkedHashSet也是非线程安全的。
4. 允许有null元素。
LinkedHashSet例子
package com.dylan.collection;
import java.util.LinkedHashSet;
/**
* @author xusucheng
* @create 2018-01-27
**/
public class LinkedHashSetExample {
public static void main(String args[]) {
// LinkedHashSet of String Type
LinkedHashSet<String> lhset = new LinkedHashSet<String>();
// Adding elements to the LinkedHashSet
lhset.add("Z");
lhset.add("PQ");
lhset.add("N");
lhset.add("O");
lhset.add("KK");
lhset.add("FGH");
System.out.println(lhset);
// LinkedHashSet of Integer Type
LinkedHashSet<Integer> lhset2 = new LinkedHashSet<Integer>();
// Adding elements
lhset2.add(99);
lhset2.add(7);
lhset2.add(0);
lhset2.add(67);
lhset2.add(89);
lhset2.add(66);
System.out.println(lhset2);
}
}
输出:
[Z, PQ, N, O, KK, FGH]
[99, 7, 0, 67, 89, 66]
分类:
Java-Core
标签:
LinkedHashSet
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 张高兴的大模型开发实战:(一)使用 Selenium 进行网页爬虫
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构