Java中的Map集合

单列集合和双列集合的区别:

单列集合一次存储一个元素

双列集合一次存储一对元素

其中双列集合中的2个元素,分别为。键不可重复,值可以重复。

Map集合概述:

Interface Map<K,V>

//K(key):键的数据类型 --V(value):值的数据类型

  • 键不可重复,值可以重复
  • 键和对是一一对应的,每一个键只能找到自己对应的值
  • 键+值整体称之为键值对(或键值对对象,Entry对象)

举例:(学号不可重复,姓名可以重复)

222123001  带小龙

222123002  付小小

222123003  带小付

222123003  带小付(错误)

222123004  带小付

记:可以将键和值比作一对夫妻,可以根据老公(键)找到老婆(值)。

创建Map集合的对象

1、多态的方式

2、具体的实现类HashMap

Map<String,String> m = new HashMap<>();
        m.put("001","小龙");
        m.put("002","小虎");
        m.put("003","小龙");
        System.out.println(m);

Map集合中的基本功能(方法):

V put(K key,V value):添加元素
V remove(Object key):根据键删除键值对元素
void clear():移除所有的键值对元素
boolean containsKey(Object key):判断集合是否包含指定的键
boolean containsValue(Object value):判断集合是否包含指定的值
boolean isEmpty():判断集合是否为空
int size():集合的长度,也就是集合中键值对的个数

Map中的遍历集合:

使用到两个方法:

第一种:先获取键再根据键获取值

  1. Set<K> keySet():获取所有键的集合
  2. V get(Object key):根据键获取值
Map<String,String > m = new HashMap<>();
        m.put("小带","小付");
        m.put("小则","小小");
        m.put("小龙","小莹");
        m.put("带带","付付");
        m.put("龙龙","莹莹");

        Set<String> k = m.keySet();//获取到所有的键
        //遍历集合得到每一个键
        //s表示集合中的每一个键元素    
        for (String s : k) {
            //通过每一个键获取到集合中对应的值,v为获取到的键对应的值的返回值
            String v = m.get(s);
            System.out.println(s + "-喜欢-" +v);      //输出
        }

运行结果:

第二种:获取到键值对对象,在分别获取到各自的值

先获取整体,再具体获取到内容。

  • Set<Map.Entry<KV>> entrySet() :获取所有键值对对象的集合
  • K getKey() :获得键
  • V getValue() :获得值
Map<String,String> p = new HashMap<>();
        p.put("小带","小付");
        p.put("小则","小小");
        p.put("小龙","小莹");
        p.put("带带","付付");
        p.put("龙龙","莹莹");

        //获取到集合中的键值对对象
        Set<Map.Entry<String, String>> entries = p.entrySet();
        for (Map.Entry<String, String> entry : entries) {
            String key = entry.getKey();                  //获取到键
            String value = entry.getValue();              //获取到值
            System.out.println(key + "=喜欢=" +value);
        }

运行结果:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值