HashSet
我仿照《java实战开发经典》这本书的一个HashSet例子敲了一组代码,为了验证HashSet无序排列,但是我输出一直是有序的ABCD,如下。。import java.util.Set;
import java.util.HashSet;
public class Puppy{
public static void main(String[] args) {
Set<String> as = new HashSet<String>();
as.add("B");
as.add("B");
as.add("B");
as.add("B");
as.add("C");
as.add("D");
as.add("D");
as.add("F");
as.add("F");
System.out.print(as);
}
}
结果如下:
这是什么鬼??
本帖最后由 zlj19931010 于 2019-1-22 15:38 编辑
public boolean add(E e) {
return map.put(e, PRESENT)==null;
}
public V put(K key, V value) {
if (key == null)
return putForNullKey(value);
int hash = hash(key.hashCode());
int i = indexFor(hash, table.length);
for (Entry<K,V> e = table; e != null; e = e.next) {
Object k;
if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
V oldValue = e.value;
e.value = value;
e.recordAccess(this);
return oldValue;
}
}
modCount++;
addEntry(hash, key, value, i);
return null;
}
hashSet实现其实就是个hashMap,添加就是往map里put
A、B、C、D这种单个字母字符串的hashCode其实就是返回ascll码数值(65 66 67 68)
排列位于table table table table
不管你是add("A");add("B");add("C");add("D");
还是add("B");add("A");add("D");add("C");
最后计算存储之后,位置都一样。
所说的乱序应该是输入输出 顺序不同 HashSet中只能存储不重复的对象,重复的对象会覆盖
页:
[1]