1. LinkedHashSet概述:
LinkedHashSet是具有可预知迭代顺序的Set接口的哈希表和链接列表实现。此实现与HashSet的不同之处在于,后者维护着一个运行于所有条目的双重链接列表。此链接列表定义了迭代顺序,该迭代顺序可为插入顺序或是访问顺序。
注意,此实现不是同步的。如果多个线程同时访问链接的哈希Set,而其中至少一个线程修改了该Set,则它必须保持外部同步。
2. LinkedHashSet的实现:
对于LinkedHashSet而言,它继承与HashSet、又基于LinkedHashMap来实现的。
LinkedHashSet底层使用LinkedHashMap来保存所有元素,它继承与HashSet,其所有的方法操作上又与HashSet相同,因此LinkedHashSet 的实现上非常简单,只提供了四个构造方法,并通过传递一个标识参数,调用父类的构造器,底层构造一个LinkedHashMap来实现,在相关操作上与父类HashSet的操作相同,直接调用父类HashSet的方法即可。LinkedHashSet的源代码如下:
public class LinkedHashSet<E> extends HashSet<E> implements Set<E>, Cloneable, java.io.Serializable { private static final long serialVersionUID = -2851667679971038690L; /** * 构造一个带有指定初始容量和加载因子的新空链接哈希set。 * * 底层会调用父类的构造方法,构造一个有指定初始容量和加载因子的LinkedHashMap实例。 * @param initialCapacity 初始容量。 * @param loadFactor 加载因子。 */ public LinkedHashSet(int initialCapacity, float loadFactor) { super(initialCapacity, loadFactor, true); } /** * 构造一个带指定初始容量和默认加载因子0.75的新空链接哈希set。 * * 底层会调用父类的构造方法,构造一个带指定初始容量和默认加载因子0.75的LinkedHashMap实例。 * @param initialCapacity 初始容量。 */ public LinkedHashSet(int initialCapacity) { super(initialCapacity, .75f, true); } /** * 构造一个带默认初始容量16和加载因子0.75的新空链接哈希set。 * * 底层会调用父类的构造方法,构造一个带默认初始容量16和加载因子0.75的LinkedHashMap实例。 */ public LinkedHashSet() { super(16, .75f, true); } /** * 构造一个与指定collection中的元素相同的新链接哈希set。 * * 底层会调用父类的构造方法,构造一个足以包含指定collection * 中所有元素的初始容量和加载因子为0.75的LinkedHashMap实例。 * @param c 其中的元素将存放在此set中的collection。 */ public LinkedHashSet(Collection<? extends E> c) { super(Math.max(2 * c.size(), 11), .75f, true); addAll(c); } }
在父类HashSet中,专为LinkedHashSet提供的构造方法如下,该方法为包访问权限,并未对外公开。
/** * 以指定的initialCapacity和loadFactor构造一个新的空链接哈希集合。 * 此构造函数为包访问权限,不对外公开,实际只是是对LinkedHashSet的支持。 * * 实际底层会以指定的参数构造一个空LinkedHashMap实例来实现。 * @param initialCapacity 初始容量。 * @param loadFactor 加载因子。 * @param dummy 标记。 */ HashSet(int initialCapacity, float loadFactor, boolean dummy) { map = new LinkedHashMap<E, Object>(initialCapacity, loadFactor); }
由上述源代码可见,LinkedHashSet通过继承HashSet,底层使用LinkedHashMap,以很简单明了的方式来实现了其自身的所有功能。
3. 相关说明:
1) 相关HashSet的实现原理,请参考:HashSet的实现原理详解
2)相关HashMap的实现原理,请参考:HashMap的实现原理详解
资料来源:http://zhangshixi.iteye.com/blog/673319
相关推荐
Java集合详解1:一文读懂ArrayList,Vector与Stack使用方法和实现原理 Java集合详解2:Queue和LinkedList Java集合详解3:Iterator,fail-fast机制与比较器 Java集合详解4:HashMap和HashTable Java集合详解5:深入...
本文将围绕Java集合框架进行详细介绍,包括Collection、List、Set、Map等基本概念及其实现原理。 #### 容器简介 在计算机科学中,容器是一种用来存储数据的对象。Java集合框架提供了一组接口和实现,这些容器用于...
1. 实现类详解: - `CopyOnWriteArraySet`:这个类基于`CopyOnWriteArrayList`实现,适用于并发环境,它在读多写少的情况下性能较好,因为读操作不会阻塞写操作。 - `HashSet`:基于哈希表(HashMap)实现,插入和...
Set接口的主要实现类包括HashSet、LinkedHashSet和TreeSet。HashSet底层使用HashMap来存储元素,所以它是无序且没有索引的,元素具有唯一性。LinkedHashSet基于HashSet,并额外维护了一个双向链表记录插入顺序,而...
##### 实现原理 - **`ArrayList`**:基于数组实现,内部使用一个数组来存储元素,提供了一种快速随机访问的方式。 - **`LinkedList`**:基于链表实现,每个节点包含一个元素和指向下一个节点的引用,适合频繁的插入...
其中,`HashSet`使用哈希表实现,`LinkedHashSet`则在此基础上保持了元素的插入顺序,而`TreeSet`则是基于红黑树的排序集合。 #### 三、`hashCode`方法详解 `hashCode`方法是`Object`类的一个方法,其目的是返回...
3. **集合内部实现**:如`ArrayList`、`LinkedList`等的具体实现原理。 4. **迭代器模式**:`Iterator`接口的作用及其使用方法。 5. **工具类使用**:`Collections`和`Arrays`提供的实用方法。 #### 集合框架详解:...
Set接口下的实现如HashSet和LinkedHashSet,其中HashSet提供快速的元素查找,但无插入顺序保证;而LinkedHashSet则保留了插入顺序,适合需要保持元素插入顺序的场景。 Map接口提供了键值对的映射,HashMap是最常见...
Java 集合类详解 Java 集合类是 Java 语言中的一种基本数据结构,用于存储和操作大量数据。集合类可以分为三大类:Collection、List 和 Set。 Collection 是集合框架中的根接口,提供了基本的集合操作,如 add、...
### Java中的Set与Map集合详解 #### 一、Set系列集合概述 Set接口是`java.util.Collection`框架的一部分,它代表一个不允许重复元素的集合。Set接口的主要特点是它不包含重复元素,即Set中不能有两个相同的对象。...
本文将详细解释 Java 中的集合框架的实现原理和使用方法。 1. 集合框架概述 集合框架是 Java 语言中的一种数据结构,它提供了一种方式来存储和处理数据。集合框架的主要作用是帮助开发者更方便地处理和存储数据,...
主要实现包括`HashSet`、`LinkedHashSet`和`TreeSet`。 - **`AbstractSet`抽象类**:为`Set`接口提供了部分默认实现。 - **`SortedSet`接口**:继承自`Set`接口,要求集合中的元素能够排序。 - **`HashSet`**:一种...
在准备Java面试时,深刻理解这些概念的基本原理及其在Java语言中的具体实现方式至关重要。同时,积累实践经验,包括使用集合、异常处理、泛型、同步和并发工具等方面的实际编码经验,将在面试中大放异彩。
Collection 集合框架详解 Collection 集合框架是 Java 语言中最基础的集合类库,它提供了一些常用的数据结构和算法,使得开发者可以更加方便地进行数据存储和处理。Collection 集合框架的顶级接口是 Collection,...
### Java学习框架详解 在Java的学习过程中,理解其核心数据结构和集合框架是至关重要的一步。根据提供的文件信息,本文将详细介绍与Java学习框架相关的几个关键知识点,包括但不限于集合框架的基本概念、各种集合类...
- **LinkedHashSet**:维护了元素的插入顺序,并且使用哈希表实现。 - **Map**:键值对集合,键是唯一的,可以通过键来查找对应的值。 - **HashMap**:基于哈希表实现,提供快速的添加和查找操作。 - **...
### Java八股文知识点详解 #### 一、集合(Collections) **1. List** - **LinkedList**: 这是一种基于链表实现的列表类型。它的主要优势在于能够高效地执行插入和删除操作,因为这些操作只需调整节点之间的链接...