【零基础学Java】—Map集合概述(四十三)

简介: 【零基础学Java】—Map集合概述(四十三)

一、Map集合概述

现实生活中,我们常会看到这样一种集合,IP地址与主机 名,身份证号与个人,系统用户名与系统对象等等,这种一一对应的关系,就叫做映射。java提供了专门的集合用来存放这种对象的关系,即java.util.Map接口。

我们通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,他们存储数据的形式不同,如下图所示:

🧨🧨🧨🧨🧨🧨总结

  • Collection中的集合,元素是孤立存在的(理解为单身),向集合中存储元素采用一个个元素的存储方式。
  • Map中的集合,元素是成对存在的(理解为夫妻关系),每个元素由键与值两部分构成,通过键可以找到对应元素的值。
  • Collection中的集合称为单列集合,Map中的集合称为双列集合。
  • 需要注意的是,Map中的集合不能包含重复的键,值可以重复,每个键只能对应一个值。

二、Map常用子类

java.util.Map<k,v>集合 implements Map<k,v>接口

🧨🧨🧨🧨🧨HashMap集合的特点:

  • HashMap集合底层是哈希表,查询的速度特别的快
  • JDK1.8之前:数组+单向链表
  • JDK1.8之后:数组+单向链表/红黑树(链表的长度超过8):提高查询的速度
  • hashMap集合是一个无序的集合,存储元素和取出元素的顺序有可能不一致
  • java.util.linkedHashMap<k,v>集合 extends HashMap<k,v> 集合

🧨🧨🧨🧨🧨linkedHashMap的特点:

  • linkedHashMap集合的底层是哈希表+链表
  • linkedHashMap集合是一个有序的集合,存储元素的取出元素的顺序都是一致的

三、Map接口中常用的方法

四、Entry键值对对象

作用:当Map集合一创建,那么就会在Map集合中创建一个Entry对象,用来记录键与值(键值对对象。键与值的映射关系)

Map集合遍历的第二种方式:使用Entry对象遍历

Map集合中的方法:

  • Set<Map,Entry<K,V>> entrySet() 返回此映射中包含的映射关系的Set视图

实现步骤:

  • 使用Map集合中的方法 entrySet(),把Map集和中的多个Entry对象取出来,存储到Set集合中
  • 遍历Set集合,获取每一个Entry对象
  • 使用Entry对象中的方法getKey()getValue()获取键与值
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
/**
 * @author :CaiCai
 * @date : 2022/4/14 14:56
 */
/*
Map集合遍历的第二种方式:使用Entry对象遍历
Map集合中的方法:
Set<Map,Entry<K,V>> entrySet()   返回此映射中包含的映射关系的Set视图
实现步骤:
使用Map集合中的方法 entrySet(),把Map集和中的多个Entry对象取出来,存储到Set集合中
遍历Set集合,获取每一个Entry对象
使用Entry对象中的方法getKey()和getValue()获取键与值
 */
public class demoMap {
    public static void main(String[] args) {
        //创建Map集合对象
        Map<String,Integer> map=new HashMap<>();
        map.put("赵丽颖",168);
        map.put("张三",179);
        map.put("李四",170);
        //使用Map集合中的方法 entrySet(),把Map集和中的多个Entry对象取出来,存储到Set集合中
        Set<Map.Entry<String,Integer>> set=map.entrySet();
        //使用迭代器遍历Set集合
        Iterator<Map.Entry<String,Integer>> it= set.iterator();
        while(it.hasNext()){
            Map.Entry<String,Integer> entry=it.next();
            //使用entry对象中的方法getkey()和getValue()获取键值
            String key=entry.getKey();
            Integer value=entry.getValue();
            System.out.println(key+"-"+value);
        }
    }
}


相关文章
|
2月前
|
Java 大数据 API
Java Stream API:现代集合处理与函数式编程
Java Stream API:现代集合处理与函数式编程
227 100
|
2月前
|
Java API 数据处理
Java Stream API:现代集合处理新方式
Java Stream API:现代集合处理新方式
258 101
|
2月前
|
算法 Java
50道java集合面试题
50道 java 集合面试题
|
1月前
|
存储 算法 安全
Java集合框架:理解类型多样性与限制
总之,在 Java 题材中正确地应对多样化与约束条件要求开发人员深入理解面向对象原则、范式编程思想以及JVM工作机理等核心知识点。通过精心设计与周密规划能够有效地利用 Java 高级特征打造出既健壮又灵活易维护系统软件产品。
67 7
|
4月前
|
Oracle Java 关系型数据库
掌握Java Stream API:高效集合处理的利器
掌握Java Stream API:高效集合处理的利器
379 80
|
4月前
|
安全 Java API
Java 8 Stream API:高效集合处理的利器
Java 8 Stream API:高效集合处理的利器
279 83
|
2月前
|
存储 Java Go
对比Java学习Go——函数、集合和OOP
Go语言的函数支持声明与调用,具备多返回值、命名返回值等特性,结合`func`关键字与类型后置语法,使函数定义简洁直观。函数可作为一等公民传递、赋值或作为参数,支持匿名函数与闭包。Go通过组合与接口实现面向对象编程,结构体定义数据,方法定义行为,接口实现多态,体现了Go语言的简洁与高效设计。
|
3月前
|
存储 缓存 安全
Java集合框架(二):Set接口与哈希表原理
本文深入解析Java中Set集合的工作原理及其实现机制,涵盖HashSet、LinkedHashSet和TreeSet三大实现类。从Set接口的特性出发,对比List理解去重机制,并详解哈希表原理、hashCode与equals方法的作用。进一步剖析HashSet的底层HashMap实现、LinkedHashSet的双向链表维护顺序特性,以及TreeSet基于红黑树的排序功能。文章还包含性能对比、自定义对象去重、集合运算实战和线程安全方案,帮助读者全面掌握Set的应用与选择策略。
234 23
|
3月前
|
存储 缓存 安全
Java集合框架(三):Map体系与ConcurrentHashMap
本文深入解析Java中Map接口体系及其实现类,包括HashMap、ConcurrentHashMap等的工作原理与线程安全机制。内容涵盖哈希冲突解决、扩容策略、并发优化,以及不同Map实现的适用场景,助你掌握高并发编程核心技巧。
|
3月前
|
安全 Java 开发者
Java集合框架:详解Deque接口的栈操作方法全集
理解和掌握这些方法对于实现像浏览器后退功能这样的栈操作来说至关重要,它们能够帮助开发者编写既高效又稳定的应用程序。此外,在多线程环境中想保证线程安全,可以考虑使用ConcurrentLinkedDeque,它是Deque的线程安全版本,尽管它并未直接实现栈操作的方法,但是Deque的接口方法可以相对应地使用。
220 12

热门文章

最新文章