• 集合的父亲之Map------(双列集合顶级接口)和遍历方式


    前言必读

    读者手册(必读)_云边的快乐猫的博客-CSDN博客

    一、概念

    1.什么是Map集合?

    答:Map双列集合和collection单列集合并列为集合的父亲。Map集合也叫键值对集合。添加元素都是成对的键值对方式添加

    2.使用场景?

    答:Map集合大多数用在做购物车这样的业务场景

    3.重点掌握与其中区别?

    答:HashMap(键--无序)、LinkeHashMap(键--有序)、TreeMap(键--排序)

    值不做要求

    4.其他知识点

    1.Map集合的键是无序、不重复的。但是值是可以重复的

    2.可以为null

    3.重复添加到同一个键的值,后面值会覆盖前面值

    4.键值对:左边是键,右边是值。例如("巧克力",100)

    二、关系图

    红色:接口

    蓝色:实现类

    例子:

    1. package bao;
    2. import java.util.Collection;
    3. import java.util.HashMap;
    4. import java.util.Map;
    5. import java.util.Set;
    6. public class Test {
    7. public static void main(String[] args) {
    8. //创建对象
    9. Map maps = new HashMap<>();
    10. //1.添加元素
    11. maps.put("小狗",1);
    12. maps.put("小鱼",1);
    13. maps.put("玫瑰",99);
    14. System.out.println(maps);//{小狗=1, 小鱼=1, 玫瑰=99}
    15. //2.判断集合是否为空,为空则返回true,不为空则false
    16. System.out.println(maps.isEmpty());
    17. //3.根据键找值
    18. Integer key = maps.get("小狗");
    19. System.out.println(key);//1
    20. //4.根据键删除整个元素
    21. maps.remove("小狗");
    22. System.out.println(maps);//{小鱼=1, 玫瑰=99}
    23. //6.判断是否包含某个键
    24. System.out.println(maps.containsKey("小鱼"));//true
    25. //7.判断是否包含某个值
    26. System.out.println(maps.containsValue(99));//true
    27. //8.获取所有键
    28. Set keys = maps.keySet();
    29. System.out.println(keys);
    30. //9.获取所有值
    31. Collection values = maps.values();
    32. System.out.println(values);
    33. //10.集合的大小
    34. System.out.println(maps.size());
    35. //11.清空集合
    36. maps.clear();
    37. System.out.println(maps);//{}
    38. //12.合并其他Map集合。(扩展)。合并集合a和集合b
    39. //创建集合a
    40. Map a = new HashMap<>();
    41. a.put("狙击枪",10);
    42. a.put("小米加步枪",60);
    43. //创建集合b
    44. Map b = new HashMap<>();
    45. a.put("散弹枪",5);
    46. a.put("小米加步枪",20);
    47. //开始合并
    48. a.putAll(b);//把集合b元素拷贝到集合a里面
    49. System.out.println(a);//{狙击枪=10, 小米加步枪=20, 散弹枪=5}
    50. }
    51. }

    =================================================遍历方式============================================

    方式一:键找值

    1. package bao;
    2. import java.util.HashMap;
    3. import java.util.Map;
    4. import java.util.Set;
    5. public class Test {
    6. public static void main(String[] args) {
    7. Map maps = new HashMap<>();
    8. //添加元素
    9. maps.put("加特林",1);
    10. maps.put("狙击枪",2);
    11. maps.put("步枪",3);
    12. //1.获取全部键
    13. Set keys = maps.keySet();
    14. //2.增强for循环遍历键
    15. for (String key : keys) {
    16. //3.使用用集合的方法get得到遍历的key。可以获得值
    17. Integer value = maps.get(key);
    18. //4.输出所有的键值
    19. System.out.println(key+value);//狙击枪2 步枪3 加特林1
    20. }
    21. }
    22. }

    运行结果:

    狙击枪2
    步枪3
    加特林1 

    方式二:键值对

    1. package bao;
    2. import java.util.HashMap;
    3. import java.util.Map;
    4. import java.util.Set;
    5. public class Test {
    6. public static void main(String[] args) {
    7. Map maps = new HashMap<>();
    8. //添加元素
    9. maps.put("加特林",1);
    10. maps.put("狙击枪",2);
    11. maps.put("步枪",3);
    12. //1.把Map集合转化为set集合..快捷方式Map.entrySet+快捷键Ctrl+Alt+v
    13. Set> entries = maps.entrySet();
    14. //2.for (<里面的那些复制过来>,自定义变量:entries)
    15. for (Map.Entry a:entries){
    16. //3.获取键和值
    17. String key = a.getKey();//获取键
    18. Integer value = a.getValue();//获取值
    19. System.out.println(key+value);//狙击枪2 步枪3 加特林1
    20. }
    21. }
    22. }

    运行结果:

    狙击枪2
    步枪3
    加特林1 

    方式三:Lambda (简便优雅,但是要熟悉使用,快捷键暂时还没有发现)

    1. package bao;
    2. import java.util.HashMap;
    3. import java.util.Map;
    4. public class Test {
    5. public static void main(String[] args) {
    6. Map maps = new HashMap<>();
    7. //添加元素
    8. maps.put("加特林",1);
    9. maps.put("狙击枪",2);
    10. maps.put("步枪",3);
    11. //方式maps.forEach((自变量1,自变量2)->{输出方法体});
    12. maps.forEach((k,v)->{
    13. System.out.println(k+v);//狙击枪2 步枪3 加特林1
    14. });
    15. }
    16. }

    运行结果:

    狙击枪2
    步枪3
    加特林1 

  • 相关阅读:
    【S0062-ssh(CNN个性化推荐算法)-基于CNN的个性化音乐推荐检索系统的设计与实现-哔哩哔哩】 https://b23.tv/zTrbnPR
    【C++Primer---C++知识点记录IV---类】
    企业架构LNMP学习笔记46
    Postman(5): postman持久化保存
    2023年 DevOps 七大趋势
    Python-pip镜像源配置及国内常用镜像源
    JetBrains系列工具,配置PlantUML绘图
    对于pytorch和对应pytorch网站的探索
    面经学习三
    Linux中的tar
  • 原文地址:https://blog.csdn.net/m0_52861000/article/details/126634562