Map 接口

Map接口实现类的特点

  1. Map 与 Collection 并列存在。用于保存具有映射关系的数据:Key-Value
  2. Map 中的 key 和 value 可以是任何引用类型的数据,会封装到HashMap$Node对象中。
  3. Map 中的 key 不允许重复,原因和HashSet 一样;若key重复,就会把value的值进行替换。
  4. Map 中的 value 可以重复。
  5. Map 中的 key 可以为 null,value 也可以为 null;注意:key 只能有一个为 null,value 可以多个为 null。
  6. 常用 String 类作为 Map 的 key。注意:不是只用 String类,只要是Object 的子类就行。
  7. key 和 value 之间存在单向一对一关系,即通过指定的 key 总能找到对应的 value。
public class Map_ {
    public static void main(String[] args) {
        // Map 接口实现类的特点,这里使用实现类HashMap
        // Map 与 Collection 并列存在。用于保存具有映射关系的数据:Key-Value
        // Map 中的 key 和 value 可以是任何引用类型的数据,会封装到HashMap$Node对象中。
        // Map 中的 key 不允许重复,原因和HashSet 一样;若key重复,就会把value的值进行替换。
        // Map 中的 value 可以重复。
        // Map 中的 key 可以为 null,value 也可以为 null;注意:key 只能有一个为 null,value 可以多个为 null。
        // 常用 String 类作为 Map 的 key。注意:不是只用 String类,只要是Object 的子类就行。
        // key 和 value 之间存在单向一对一关系,即通过指定的 key 总能找到对应的 value。

        Map map = new HashMap();
        map.put("01","魅族"); //k-v
        map.put("02","苹果"); //k-v
        map.put("01","华为"); //当有相同的k ,就会对value 进行替换
        map.put("03","华为"); //k-v
        map.put(null,null); //k-v
        map.put(null,"abc");//替换
        map.put("04",null); //k-v
        map.put("05",null); //k-v
        map.put(1,"小米"); //k-v
        map.put(new Object(),"三星"); //k-v

        // 通过get 方法,传入key ,会返回对应的value 值。
        System.out.println(map.get("02")); //苹果
        System.out.println(map);

    }
}

输出:

苹果
{null=abc, 01=华为, 1=小米, 02=苹果, 03=华为, 04=null, 05=null, java.lang.Object@1b6d3586=三星}

Map接口特点

  1. k-v 最后是存放在 HashMap$Node node = newNode(hash,key,value,null)
  2. k-v 为了方便程序员遍历,还会创建 EntrySet 集合,该集合存放的元素的类型 Entry,而一个Entry 对象就有 k,v EntrySet<Entry<K,V>> 即:transient Set<Map.Entry<K,V>> entrySet
  3. entrySet 中,定义的类型是 Map.Entry,但实际上存放的还是 HashMap$Node,这是因为 static class Node<K,V> implements Map.Entry<K,V>
  4. 当把 HashMap$Node 对象存放到 entrySet 就会放方便我们遍历,因为 Map.Entry 提供了重要的方法: K getKey();  V getValue();

Map接口常用方法

  1. put:添加元素
  2. remove:根据k键 删除元素
  3. get:根据 k键 获得元素
  4. size:获取元素个数
  5. isEmpty:判断个数是否为0
  6. clear:清楚
  7. containsKey:查找 键 是否存在
Map map = new HashMap();
        map.put("01","魅族"); //k-v
        map.put("02","苹果"); //k-v
        map.put("01","华为"); //当有相同的k ,就会对value 进行替换
        map.put("03","华为"); //k-v
        map.put(null,null); //k-v
        map.put(null,"abc");//替换
        map.put("04",null); //k-v
        map.put("05",null); //k-v
        map.put(1,"小米"); //k-v

        System.out.println(map);

        //根据键删除元素
        map.remove(1);
        System.out.println(map);
        //根据键获取元素
        System.out.println(map.get("01"));
        //获取元素个数
        System.out.println("K-V: "+ map.size()+"个");
        //判断个数是否为 0 
        System.out.println(map.isEmpty());
        //查找键是否存在
        System.out.println(map.containsKey("1"));

输出:

{null=abc, 01=华为, 1=小米, 02=苹果, 03=华为, 04=null, 05=null}
{null=abc, 01=华为, 02=苹果, 03=华为, 04=null, 05=null}
华为
K-V: 6个
false
false

进程已结束,退出代码0

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值