鱼C论坛

 找回密码
 立即注册
查看: 2514|回复: 2

[已解决]HashSet

[复制链接]
发表于 2019-1-17 17:10:39 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
我仿照  《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);
               
               
               
        }       
       
}


结果如下:

[B, C, D, F]

这是什么鬼??

最佳答案
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[i]; 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[65] table[66] table[67] table[68]
不管你是add("A");add("B");add("C");add("D");
还是add("B");add("A");add("D");add("C");
最后计算存储之后,位置都一样。

所说的乱序应该是输入输出 顺序不同
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 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[i]; 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[65] table[66] table[67] table[68]
不管你是add("A");add("B");add("C");add("D");
还是add("B");add("A");add("D");add("C");
最后计算存储之后,位置都一样。

所说的乱序应该是输入输出 顺序不同
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-1-30 16:24:19 | 显示全部楼层
HashSet中只能存储不重复的对象,重复的对象会覆盖
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-5 21:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表