首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >HashSet vs LinkedHashSet

HashSet vs LinkedHashSet
EN

Stack Overflow用户
提问于 2011-02-23 00:04:34
回答 10查看 124.6K关注 0票数 165

它们之间的区别是什么?我知道

A LinkedHashSet是HashSet的有序版本,它跨所有元素维护一个双向链表。当您关心迭代顺序时,请使用此类而不是HashSet。当您遍历HashSet时,顺序是不可预测的,而LinkedHashSet允许您按照元素插入的顺序遍历元素。

但在LinkedHashSet源码中,只有HashSet的调用构造函数。那么,双向链表和插入顺序在哪里呢?

EN

回答 10

Stack Overflow用户

回答已采纳

发布于 2011-02-23 00:10:47

答案就在中,LinkedHashSet使用哪个构造函数来构造基类:

代码语言:javascript
复制
public LinkedHashSet(int initialCapacity, float loadFactor) {
    super(initialCapacity, loadFactor, true);      // <-- boolean dummy argument
}

...

public LinkedHashSet(int initialCapacity) {
    super(initialCapacity, .75f, true);            // <-- boolean dummy argument
}

...

public LinkedHashSet() {
    super(16, .75f, true);                         // <-- boolean dummy argument
}

...

public LinkedHashSet(Collection<? extends E> c) {
    super(Math.max(2*c.size(), 11), .75f, true);   // <-- boolean dummy argument
    addAll(c);
}

下面描述了一个接受布尔参数的HashSet构造函数(一个示例),它看起来如下所示:

代码语言:javascript
复制
/**
 * Constructs a new, empty linked hash set.  (This package private
 * constructor is only used by LinkedHashSet.) The backing
 * HashMap instance is a LinkedHashMap with the specified initial
 * capacity and the specified load factor.
 *
 * @param      initialCapacity   the initial capacity of the hash map
 * @param      loadFactor        the load factor of the hash map
 * @param      dummy             ignored (distinguishes this
 *             constructor from other int, float constructor.)
 * @throws     IllegalArgumentException if the initial capacity is less
 *             than zero, or if the load factor is nonpositive
 */
HashSet(int initialCapacity, float loadFactor, boolean dummy) {
    map = new LinkedHashMap<E,Object>(initialCapacity, loadFactor);
}
票数 68
EN

Stack Overflow用户

发布于 2016-07-01 17:33:23

HashSet是无序和无序的集合。

LinkedHashSet是HashSet的订购版本。

HashSetLinkedHashSet之间的唯一区别是:

LinkedHashSet会维护插入顺序。

当我们遍历HashSet时,顺序是不可预测的,而对于LinkedHashSet.,顺序是可预测的

LinkedHashSet保持插入顺序的原因是:

底层使用的数据结构是Doubly-Linked-List.

票数 32
EN

Stack Overflow用户

发布于 2011-02-23 00:11:49

LinkedHashSet的构造函数调用以下基类构造函数:

代码语言:javascript
复制
HashSet(int initialCapacity, float loadFactor, boolean dummy) {
  map = new LinkedHashMap<E, Object>(initialCapacity, loadFactor);
}

如您所见,内部映射是一个LinkedHashMap。如果您查看LinkedHashMap内部,您将发现以下字段:

代码语言:javascript
复制
private transient Entry<K, V> header;

这就是有问题的链表。

票数 25
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5080612

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档