海绵爱上星 发表于 2019-1-17 17:10:39

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 14:24:39

本帖最后由 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");
最后计算存储之后,位置都一样。

所说的乱序应该是输入输出 顺序不同

18630145849 发表于 2019-1-30 16:24:19

HashSet中只能存储不重复的对象,重复的对象会覆盖
页: [1]
查看完整版本: HashSet