gpt4 book ai didi

java - HashSet 与 LinkedHashSet 性能测试

转载 作者:行者123 更新时间:2023-11-30 08:01:53 25 4
gpt4 key购买 nike

来自here我认为 HashSet 的性能比 LinkedHashSet 稍好。但是当尝试执行示例程序时,我得到了不同的结果。

     /*
* HashSet not order not sorted
*/
long hsTime = System.nanoTime();
Set<String> hs = new HashSet<String>();
// add elements to the hash set
hs.add("B");
hs.add("A");
hs.add("D");
hs.add("E");
hs.add("C");
hs.add("F");
System.out.println("HashSet ---->"+hs); // HashSet ---->[D, E, F, A, B, C]
System.out.println("Execution time HashSet ---->"+(System.nanoTime() - hsTime)); // Execution time HashSet ---->275764

/*
* LinkedHashSet will maintain its insertion order but no sorting
*/
long lhsTime = System.nanoTime();
Set<String> lhs = new LinkedHashSet<String>();
// add elements to the hash set
lhs.add("B");
lhs.add("A");
lhs.add("D");
lhs.add("E");
lhs.add("C");
lhs.add("F");
System.out.println("LinkedHashSet ---->"+lhs); //LinkedHashSet ---->[B, A, D, E, C, F]
System.out.println("Execution time LinkedHashESet ---->"+(System.nanoTime() - lhsTime)); // Execution time LinkedHashESet ---->201181

显示 LinkedHashSet 具有更好的性能。有人可以澄清哪一个具有更好的性能吗?

注意:当我注释掉这两行时:

System.out.println("HashSet ---->"+hs);
System.out.println("LinkedHashSet ---->"+lhs);

它显示 HashSet 具有更好的性能。输出是

Execution time HashSet ---->32304
Execution time LinkedHashESet ---->74414

最佳答案

我怀疑这是由于在以下语句中输出 HashSet 时执行第一个循环时 JVM 所花费的预热时间造成的:

System.out.println("HashSet ---->"+hs);

这相当于类似的东西

Iterator<E> i = iterator();
if (! i.hasNext())
return "[]";

StringBuilder sb = new StringBuilder();
sb.append('[');
for (;;) {
E e = i.next();
sb.append(e == this ? "(this Collection)" : e);
if (! i.hasNext())
return sb.append(']').toString();
sb.append(", ");
}
System.out.println("HashSet ---->" + sb.toString());

关于java - HashSet 与 LinkedHashSet 性能测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31793284/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com