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,看不出来有何关系。
求各位大神解答下~~ 谢啦~~