Java集合——Map接口实现类的源码剖析——最认真的图解——第三章

1:集合体系图

Collection:单列集合,该接口有两个重要的子接口List Set,他们的实现子类都是单列集合
在这里插入图片描述
Map:双列集合,Map接口的实现子类,存放K-V
在这里插入图片描述

2:Map接口特点和方法

  1. Map与Collection并列存在。用于保存具有映射关系的数据:Key-Value

  2. Map中的key和value 可以是任何引用类型的数据,会封装到HashMap$Node对象中

  3. Map中的key不允许重复,原因和HashSet一样,前面分析过源码.(当有相同的k,就等价于替换,为什么呢?看如下的源码)
    对应的HashMap源码中的

    final V putVal(int hash, K key, V value, boolean onlyIfAbsent,
//..
if (e != null) {
    // existing mapping for key
                V oldValue = e.value;
                if (!onlyIfAbsent || oldValue == null)
                    e.value = value;
                afterNodeAccess(e);
                return oldValue;
            }
            //....
  1. Map中的value可以重复

  2. Map的key可以为null, value也可以为null ,

注意key为null,只能有一个,value为null ,可以多个.

  1. 常用String类作为Map的key

  2. key和value之间存在单向一对一关系,即通过指定的key总能找到对应的value
    案例演示

public class Map_ {
   
    public static void main(String[] args) {
   
        Map hashMap = new HashMap();
        hashMap.put("no1","zlj");
        hashMap.put("no2","zzz");
        hashMap.put("no1","zl");//当有相同的k,就等价于替换
        hashMap.put("no3","zlj");
        hashMap.put(null,null);
        hashMap.put(null,"zzg");
        hashMap.put("no4",null);
        hashMap.put("no5",null);
        System.out.printl
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值