Java——集合中的Map接口通过HashMap类实现一些常用的方法

简介: Java——集合中的Map接口通过HashMap类实现一些常用的方法

任何复杂的知识往往给人的感觉都是那么的不友好,所以,一定要静下心来,耐心去看、去读、去理解这些东西!!!  


1.Map接口简介


说明:Map接口是一种双列集合,它的每个元素都包含一个键对象 Key 和值对象 Value,键和值对象之间存在一种对应关系,称为映射。 那什么是映射呢?在生活中,我们常常会看到这样的一种集合:账号——密码、IP地址——主机名、系统用户名——系统用户对象等。像这种一一对应的关系,就叫做映射。


特点:①Map集合是一个双列集合,一个元素包含两个值(一个key,一个value)。


          ②Map集合中的元素,key 和 value 的数据类型可以相同,也可以不同。


          ③Map集合中的元素,key 是不允许重复的, value 是可以重复的。


          ④Map集合中的元素,key 和 value是一一对应的。



2.HashMap类简介


说明:HashMap 是 Map 接口的一个实现类,它用于存储键值映射关系,该集合的键和值允许为空,但键不能重复,且集合中的元素是无序的。


特点:HashMap 底层是由哈希表结构组成的,其实就是“数组+链表”的组合体,数组是 HashMap 的主体结构,链表则主要是为了解决哈希值冲突而存在的分支结构。正因为这样特殊的存储结构,HashMap 集合对于元素的增、删、改、查操作表现出的效率都比较高。


2.1 内部结构  



2.2 存储原理


 

3.Map接口常用的方法



4.应用举例

import java.util.*;
/*import java.util.Map;
  import java.util.HashMap;
  import java.util.Collection;
  import java.util.Set;
  import java.util.Iterator;*/
public class MapDemo {
  public static void main(String[] args) {
    //用多态的形式,创建一个hashmap集合,集合长度为16
    Map<String,String> hashmap=new HashMap<String,String>(16);
    System.out.println("↓↓↓Map集合常用方法如下↓↓↓");
    System.out.println("---------------------------------------------");
    System.out.println("创建第一个空的hashmap集合,键、值类型均为String类:" + hashmap);
    System.out.println("---------------------------------------------");
    hashmap.put("公共的","public");
    hashmap.put("受保护的","protected");
    hashmap.put("默认的","friendly");
    hashmap.put("默认的","default");//覆盖这个键之前对应的值
    hashmap.put("私有的","private");
    System.out.println("向hashmap集合中添加键值对元素:" + hashmap);
    System.out.println("此时hashmap集合中键值对的个数为:" + hashmap.size());
    System.out.println("---------------------------------------------");
    System.out.println("获取hashmap集合中键\"公共的\"所映射的值:" + hashmap.get("公共的"));
    System.out.println("---------------------------------------------");
    System.out.println("查看hashmap集合中是否存在键对象\"私有的\":" + hashmap.containsKey("私有的"));
    System.out.println("查看hashmap集合中是否存在值对象\"protected\":" + hashmap.containsValue("protected"));
    System.out.println("---------------------------------------------");
    String str1=hashmap.remove("默认的");
    System.out.println("将指定的键所对应的键值对元素移除,并返回该元素的值:" + str1);
    System.out.println("移除之后,hashmap集合为:" + hashmap);
    System.out.println("---------------------------------------------");
    Set<String> set=hashmap.keySet();
    System.out.println("以Set集合的形式返回hashmap集合中所有的键对象:" + set);
    System.out.println("---------------------------------------------");
    Collection<String> collection=hashmap.values();
    System.out.println("以Collection集合的形式返回hashmap集合中所有的值对象:" + collection);
    System.out.println("---------------------------------------------");
    Set<Map.Entry<String,String>> setmap=hashmap.entrySet();
    System.out.println("将hashmap集合转换为存储元素类型为Map的Set集合:" + setmap);
    System.out.println("---------------------------------------------");
    System.out.println("Iterator迭代器遍历Map集合——keySet()方法:");
    Set<String> setkey1=hashmap.keySet();//以Set集合的形式返回hashmap集合中所有的键对象
    Iterator<String> iterator1=setkey1.iterator();//获取Set集合的迭代器对象,并遍历该迭代器对象
    while(iterator1.hasNext()) {
      Object key1=iterator1.next();//获取键
      Object value1=hashmap.get(key1);//通过键获取相应的值
      System.out.println("键:" + key1 + ",值:" + value1);
    }
    System.out.println("---------------------------------------------");
    System.out.println("Iterator迭代器遍历Map集合——entrySet()方法:");
    Set<Map.Entry<String,String>> setkey2=hashmap.entrySet();//将hashmap集合转换为存储元素类型为Map的Set集合
    Iterator<Map.Entry<String,String>> iterator2=setkey2.iterator();//获取Set集合的迭代器对象,并遍历该迭代器对象
    while(iterator2.hasNext()) {
      //通过Entry对象的getKey()和getValue()方法,获取键和值
      Map.Entry<String,String> kv=iterator2.next();
      Object key2=kv.getKey();
      Object value2=kv.getValue();
      System.out.println("键:" + key2 + ",值:" + value2);
    }
    System.out.println("---------------------------------------------");
    System.out.println("使用Lambda表达式的书写形式来遍历Map集合:");
    //JDK 8新方法遍历Map集合(Lambda表达式特性),这里也可以使用for-each循环对hashmap集合进行遍历
    hashmap.forEach((key,value)->System.out.println("键:" + key + ",值:" + value));
    System.out.println("---------------------------------------------");
    hashmap.clear();
    System.out.println("清空hashmap集合中的所有键值对元素:" + hashmap);
    System.out.println("---------------------------------------------");
  }
}


相关文章
|
2月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
114 4
|
2月前
|
IDE JavaScript Java
在Java 11中,如何处理被弃用的类或接口?
在Java 11中,如何处理被弃用的类或接口?
200 5
|
2月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
193 1
|
2月前
|
Java Go 开发工具
【Java】(8)正则表达式的使用与常用类分享
正则表达式定义了字符串的模式。正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别。
241 1
|
6月前
|
存储 安全 Java
Java 集合面试题从数据结构到 HashMap 源码剖析详解及长尾考点梳理
本文深入解析Java集合框架,涵盖基础概念、常见集合类型及HashMap的底层数据结构与源码实现。从Collection、Map到Iterator接口,逐一剖析其特性与应用场景。重点解读HashMap在JDK1.7与1.8中的数据结构演变,包括数组+链表+红黑树优化,以及put方法和扩容机制的实现细节。结合订单管理与用户权限管理等实际案例,展示集合框架的应用价值,助你全面掌握相关知识,轻松应对面试与开发需求。
336 3
|
Java
让星星⭐月亮告诉你,HashMap中保证红黑树根节点一定是对应链表头节点moveRootToFront()方法源码解读
当红黑树的根节点不是其对应链表的头节点时,通过调整指针的方式将其移动至链表头部。具体步骤包括:从链表中移除根节点,更新根节点及其前后节点的指针,确保根节点成为新的头节点,并保持链表结构的完整性。此过程在Java的`HashMap$TreeNode.moveRootToFront()`方法中实现,确保了高效的数据访问与管理。
126 2
|
Java 索引
让星星⭐月亮告诉你,HashMap之往红黑树添加元素-putTreeVal方法源码解读
本文详细解析了Java `HashMap` 中 `putTreeVal` 方法的源码,该方法用于在红黑树中添加元素。当数组索引位置已存在红黑树类型的元素时,会调用此方法。具体步骤包括:从根节点开始遍历红黑树,找到合适位置插入新元素,调整节点指针,保持红黑树平衡,并确保根节点是链表头节点。通过源码解析,帮助读者深入理解 `HashMap` 的内部实现机制。
206 2
|
算法 Java 容器
Map - HashSet & HashMap 源码解析
Map - HashSet & HashMap 源码解析
194 0
|
12月前
|
存储 缓存 Java
HashMap源码剖析-put流程
更好地掌握 `HashMap` 的内部实现原理,提高编写高效代码的能力。掌握这些原理不仅有助于优化性能,还可以帮助解决实际开发中的问题。
363 13
|
12月前
HashMap源码浅分析与解读
阿华代码解读,不是逆风就是你疯HashMap 和TreeMap都继承于Map,Map是一个接口在实现这个接口的时候,需要实例化TreeMap或者HashMap。

热门文章

最新文章