集合(开发重点)

三、Map集合体系

  1. Map集合的特点:【基础重点】
    (1) 存储任意的 键值对 (key-value),Map中一个集合元素是一个键值对
    (2) 键:无序、无下标、不允许重复(唯一)
    (3) 值:无序、无下标、允许重复
  2. Map 集合中的方法
    (1) V put(K key,V value) : 往Map集合中添加一个键值对,如果键在Map中没有存在,则直接添加,返回值为
    null;如果键在Map中已经存在,则新的Value覆盖原有的value数据,被覆盖的value数据作为返回
    值进行返回。【开发重点】
    (2) V remove(K key):根据键,删除对应的键值对,被删除的值(value)作为返回值返回。
    (3) V get(K key):根据键,返回对应的值(value)。【重点】
    (4) boolean containsKey(K key):判断Map集合中是否包含指定的键,包含-true;不包含-false.
    (5) boolean containsValue(V value):判断Map集合中是否包含指定的值,包含-true;不包含-false.
    (6) int size() : 获取Map中键值对的个数。
  3. 实现类:HashMap
    注意:如果自定类型的对象存储在HashMap的键上,为保证键的不允许重复,则自定义类型的对象对应的类
    需要覆盖hashCode方法和equals方法;但是开始通常用 String/Integer类型的数据作为键。
    (1) HashMap: JDK1.2 版本,线程不安全,运行效率较高,允许null 作为 key/value。【开发重点】
    (2) Hashtable : JDK1.0版本,线程安全,运行效率慢,不允许null作为key/value。 (3) Properties:是 Hashtable的子类,要求 键和值都是String类型。开发时,通常用于读取配置文件。
    (4) SortedMap : 是 Map子接口,可以对键完成自动排序。实现类:TreeMap
    (5) LinkedHashMap:是 HashMap的子类,按照添加的顺序完成键值对的存储。
    面试题目:HashMap 和 Hashtable的区别。
  4. 遍历:
    (1) 第一种遍历方式:键遍历,通过 keySet()方法获取Map 所有的键 【开发应用重点】
    Set< K > ks = map.keySet(); // 获取所有的键
    // 利用 foreach遍历 set集合
    for(K key : ks){
    // 通过 map 的 get方法,获取键对应的值
    V value = map.get(key);
    // 利用 key 和 value 操作每一个键和值即可
    }
    (2) 第二种遍历方式:值遍历 ,通过 values() 获取 Map中所有的值
    Collection< V > vs = map.values();
    //利用 foreach 遍历 Collection集合
    for(V value:vs){
    // 通过 value 操作对应的值
    }
    (3) 第三种遍历方式:键值对遍历,通过 entrySet方法获取Map中所有键值对
    Set< Map.Entry< K,V>> kvs = map.entrySet();
    // 通过foreach遍历 set集合 获取每一个键值对(Entry)
    for(Map.Entry< K,V> kv : kvs ){
    // 利用 Entry中提供两个方法 getKey 和 getValue 获取键和值的信息
    K key = kv.getKey(); // 从键值对中获取键的信息
    V value = kv.getValue() ; // 从键值对中获取值的信息
    // 通过 key 和 value 操作键和值
    }
相关推荐
漫霂2 分钟前
二叉树的翻转
java·数据结构·算法
语戚2 分钟前
力扣 51. N 皇后:基础回溯、布尔数组优化、位运算全解(Java 实现)
java·算法·leetcode·力扣·剪枝·回溯·位运算
维度攻城狮9 分钟前
pycallgraph2drawio:Python 调用链可视化 + Draw.io 自由编辑
开发语言·python·draw.io·graphviz
程序猿阿越12 分钟前
Kafka4源码(三)Share Group共享组
java·后端·源码阅读
亦暖筑序14 分钟前
让AI不再"一本正经胡说八道":Spring AI RAG与VectorStore源码全解
java·源码阅读
蒙奇·D·路飞-18 分钟前
大模型时代下 Java 后端开发的技术重构与工程实践
java·开发语言·重构
wljy120 分钟前
Qt入门(一)
开发语言·qt
ZK_H1 小时前
半导体工艺流程
java·c语言·开发语言·计算机网络·金融
计算机安禾1 小时前
【数据结构与算法】第39篇:图论(三):最小生成树——Prim算法与Kruskal算法
开发语言·数据结构·c++·算法·排序算法·图论·visual studio code
liliangcsdn1 小时前
sentence-transformer如何离线加载和使用模型
开发语言·前端·php