yutongliankong 2014-04-24 09:45
浏览 1052

HashSet元素存储问题,求大神解答下~~

package test;

import java.util.HashSet;

import java.util.Iterator;

import java.util.Set;

public class Test {

public static void main(String[] args) {  

    Set<String> set = new HashSet<String>();  
    set.add("one");  
    set.add("four");  
    set.add("three");  
    set.add("five");  
    set.add("two");  
    System.err.println(set);
    for (Iterator<String> it = set.iterator(); it.hasNext();) {  
        System.err.println(it.next());  
    }  
}  

}

HashSet是无序的,但是为何存入其中的元素每次迭代打印的顺序是相同的?变化插入的顺序返回的结果仍相同。如下:
[two, five, one, three, four]
two
five
one
three
four

和散列码的关系到底是怎样的?String重写了hashCode方法,执行结果对应的散列码分别为115276、3143346、110182、110339486、3149094,看不出来有何关系。
求各位大神解答下~~ 谢啦~~

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 程序不包含适用于入口点的静态Main方法
    • ¥15 素材场景中光线烘焙后灯光失效
    • ¥15 请教一下各位,为什么我这个没有实现模拟点击
    • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
    • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
    • ¥20 有关区间dp的问题求解
    • ¥15 多电路系统共用电源的串扰问题
    • ¥15 slam rangenet++配置
    • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
    • ¥15 ubuntu子系统密码忘记