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条回答

    报告相同问题?

    悬赏问题

    • ¥20 sub地址DHCP问题
    • ¥15 delta降尺度计算的一些细节,有偿
    • ¥15 Arduino红外遥控代码有问题
    • ¥15 数值计算离散正交多项式
    • ¥30 数值计算均差系数编程
    • ¥15 redis-full-check比较 两个集群的数据出错
    • ¥15 Matlab编程问题
    • ¥15 训练的多模态特征融合模型准确度很低怎么办
    • ¥15 kylin启动报错log4j类冲突
    • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大