Java数组+链表简单实现HashMap的put和get

本例子实现了Java数组+链表实现HashMap,可往HashMap中存null值。

public class MyHashMap<K,V> {

    //定义一个数组
    private Entry<K,V>[] entries=new Entry[1000];

    class Entry<K,V>{
        K k;
        V v;
        Entry next;

        public Entry(K k, V v) {
            this.k = k;
            this.v = v;
        }
    }

    public void put(K k,V v){
        //计算出存放在数组中的位置,k为null则直接存放在index=0位置
        int index = k==null ? 0: k.hashCode()%entries.length;
      //  System.out.println(index);

        //若数组中此时无值,则可直接存入
        if(entries[index]==null){
            entries[index]=new Entry<>(k,v);
        }else {
            //发生了hash冲突
            entries[index].next=new Entry(k,v);
        }

    }
    public V get(K k){
        int index = k==null ? 0: k.hashCode()%entries.length;
        while (entries[index]!=null){
            //这一步很重要
            if(entries[index].k==null||entries[index].k.equals(k)){
                return entries[index].v;
            }
            entries[index]=entries[index].next;
        }
        return null;
    }

    public static void main(String[] args) {
        MyHashMap<Object,Object> myHashMap=new MyHashMap<>();
        myHashMap.put("a","cc");
        System.out.println(myHashMap.get("a"));
        myHashMap.put(97,"dd");
        System.out.println(myHashMap.get(97));
        myHashMap.put(null,"ee");
        System.out.println(myHashMap.get(null));
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值