Map集合

在现实生活中,有非常多的东西,是和另外一种东西对应的,并且还是唯一的,比如:身份证号与个人,个人与手机,一夫一妻。。。等,这种关系就是对应关系,又叫做映射。Java为这种数据类型提供了专门的接口,就是Map<K,V>接口。

Map<K,V>集合的特点

  • Map<K,V>集合是一个双列集合,一个元素包含两个值。
  • Map<K,V>集合中的元素,key和value的数据类型可以相同,也可以不相同。
  • Map<K,V>集合中的元素,key是不允许重复的,但是value可以重复。
  • Map<K,V>集合中的元素,key和value是一一对应的。

Map<K,V>集合与Collection的区别

  • Collection中的集合,元素是孤立存在的,而Map<K,V>集合中的元素是成对出现的。
  • Collection集合称为单列集合,Map<K,V>集合称为双列集合。

Map<K,V>的常用方法

Map<K,V>中定义了很多方法,都是它的子类常用的方法,只要会用这几个方法,Map集合就等于会了,只用再了解一下,每一个子类的做用就行了。

方法

  • public V put(K key,V value); 把指定的键与指定折值添加到Map集合中。
  • public V remove(Object key); 把指定的键所对应的键值对元素在Map集合中删除,返回被删除元素的值。
  • public V get(Object key); 根据指定的键,在Map集合中取对应的值。
  • public Set<K> keySet(); 获取Map集合中所有的键,存到Set集合中去。
  • public Set<Map.Entry<K,V>> entrySet(); 获取Map集合中所有的键值对对象的集合。

使用

public V put(K key,V value); 把指定的键与指定折值添加到Map集合中。

    Map<Integer, String> map = new HashMap<>();
map.put(1, "a");
map.put(2, "b");
map.put(3, "c");
map.put(4, "d");
//只可以存储一个null键
map.put(null, "e");
//Map集合是无序的
System.out.println(map); //{null=e, 1=a, 2=b, 3=c, 4=d}

public V remove(Object key); 把指定的键所对应的键值对元素在Map集合中删除,返回被删除元素的值。

   //数据为上面的数据
//删除key为null的元素
String remove = map.remove(null);
//返回值是被删除的元素的value
System.out.println(remove); //e
System.out.println(map); //{1=a, 2=b, 3=c, 4=d}

public V get(Object key); 根据指定的键,在Map集合中取对应的值。

   String s = map.get(2);
System.out.println(s); //b
System.out.println(map); //{null=e, 1=a, 2=b, 3=c, 4=d}

public Set<K> keySet(); 获取Map集合中所有的键,存到Set集合中去。

   //取出Map集合中所有的key
Set<Integer> integers = map.keySet();
//对Map集合进行遍厉的时候才使用的
for (Integer integer :integers) {
//用get方法通过key来获取值
String s = map.get(integer);
System.out.println(s);
}
//也可以使用Set集合里面的迭代器来进行循环

public Set<Map.Entry<K,V>> entrySet(); 获取Map集合中所有的键值对对象的集合。

    //这也是一种遍厉Map集合的方法
Set<Map.Entry<Integer, String>> entries = map.entrySet();
for (Map.Entry<Integer, String> entry : entries) {
//用Map.Entry里面的getKey和getValue方法来获取key和value
System.out.print("key:" + entry.getKey());
System.out.println("value:" + entry.getValue());
/*
key:nullvalue:e
key:1value:a
key:2value:b
key:3value:c
key:4value:d
*/
}

Entry<K,V>Map接口,中是一个内部接口,并且在所有的实现类中实现,这个实现类的做用是用来记录Map集合中所有的Key和对应的Value

HashMap<K,V>集合

存储数据用的是哈希表结构,元素存取是无序。因为要保证唯一,所以必须要保证,key的对象必须要重写hashCode()方法和equals()方法。


因为基本数据类型里面都重写了这两个方法,所以我自定义一个对象做为key值,看看重写了这两个方法和不重写了这两个方法的区别。

重写:

    Map<Student, String> stuMap = new HashMap<>();
stuMap.put(new Student("张三", 18), "不重写");
stuMap.put(new Student("张三", 18), "不重写");
stuMap.put(new Student("王五", 13), "不重写");
stuMap.put(new Student("赵六", 15), "不重写");
System.out.println(stuMap);//四个数据全有
//{Student{name='王五', age=13}=不重写, Student{name='张三', age=18}=不重写,
// Student{name='张三', age=18}=不重写, Student{name='赵六', age=15}=不重写}

不重写:

    Map<Student, String> stuMap = new HashMap<>();
stuMap.put(new Student("张三", 18), "重写");
stuMap.put(new Student("张三", 18), "重写");
stuMap.put(new Student("王五", 13), "重写");
stuMap.put(new Student("赵六", 15), "重写");
System.out.println(stuMap);//重复的张三没有了
//{Student{name='张三', age=18}=不重写, Student{name='赵六', age=15}=不重写,
// Student{name='王五', age=13}=不重写}

上面的重复虽然保证唯一了,但是没有保证有序,所以我们就要用到LinkedHashMap集合。

LinkedHashMap<K,V>集合

LinkedHashMapHashMap下面的子类,HashMap的所有的方法,LinkedHashMap都有,但是LinkedHashMapHashMap好用的一点是,它可以保证存取的顺序一致。

    Map<Student, String> stuMap = new LinkedHashMap<>();
stuMap.put(new Student("张三", 18), "重写");
stuMap.put(new Student("张三", 18), "重写");
stuMap.put(new Student("王五", 13), "重写");
stuMap.put(new Student("赵六", 15), "重写");
System.out.println(stuMap);//顺序和存的顺序一样了
//{Student{name='张三', age=18}=重写, Student{name='王五', age=13}=重写,
//Student{name='赵六', age=15}=重写}

上面的这两个实现类都是同步的!


细节决定成败!

个人愚见,如有不对,恳请扶正!

Java | Map集合的更多相关文章

  1. Java Map 集合实现类

    Map 用于保存具有映射关系的数据,集合里会保存两组值,一组用于保存Map里的key,一组用于保存Map里的value,key与map可以是任何引用类型数据.Map的key不允许重复.key与valu ...

  2. Java Map集合 遍历 五种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.HashMap; import java.util.Iterator; import ...

  3. java Map集合对比分析

    1.Map:Map是所有map集合的顶级父接口,用于key/value形式的键值对,其中每一个key都映射到一个值,key不能重复. 2.TreeMap:该map将存储的键值对进行默认排序,并且还能够 ...

  4. Java Map集合按照key和value排序之法

    一.理论基点 Map是键值对的集合接口,它的实现类主要包括:HashMap,TreeMap,Hashtable以及LinkedHashMap等. TreeMap:基于红黑树(Red-Black-Tre ...

  5. Java学习笔记之:Java Map集合

    一.介绍 通常来说,Map是一个由键值对组成的数据结构,且在集合中每个键是唯一的. 二.笔记 /** * Map:接口. 不是collection的子类 key -value 键值对 key唯一不能重 ...

  6. java map集合的知识

    /** * Map用于存储键值对,不允许键重复,值可以重复. * (1)HashMap是一个最常用的Map,它根据键的hashCode值存储数据,根据键可以直接获取它的值,具有很快的访问速度. * H ...

  7. java map集合 --遍历

    1.Map 遍历: Map<Integer, String> map = new HashMap<Integer, String>(); map.put(1, "a& ...

  8. java Map集合学习

    学习语法还是从例子着手: FileDao fileDao=new FileBeanDaoImpl(); FileBean fileBean=new FileBean(); listBean=fileD ...

  9. Java版本:识别Json字符串并分隔成Map集合

    前言: 最近又看了点Java的知识,于是想着把CYQ.Data V5迁移到Java版本. 过程发现坑很多,理论上看大部分很相似,实践上代码写起来发现大部分都要重新思考方案. 遇到的C#转Java的一些 ...

随机推荐

  1. Django中数据库操作相关的错误

    问题:字段修改属性发生错误 1> >python manage.py makemigrations You are trying to add a non-nullable field ' ...

  2. 多视觉任务的全能: HRNet

    多视觉任务的全能: HRNet HRNet是微软亚洲研究院的王井东老师领导的团队完成的,打通图像分类.图像分割.目标检测.人脸对齐.姿态识别.风格迁移.Image Inpainting.超分.opti ...

  3. BlazorCharts 原生图表库的建设历程

    作者:陈超超 Ant Design Blazor 项目贡献者,拥有十多年从业经验,长期基于.Net技术栈进行架构与开发产品的工作,现就职于正泰集团. 邮箱:timchen@live.com 欢迎各位读 ...

  4. 前端 JS 之 AJAX 简介及使用

    概述 AJAX 是一个缩写,它的全名是 Asynchronous JavaScript and XML,意思就是异步 JavaScript 和 XML,即用JavaScript执行异步网络请求. AJ ...

  5. P1123 取数游戏

    题目描述 一个N \times MN×M的由非负整数构成的数字矩阵,你需要在其中取出若干个数字,使得取出的任意两个数字不相邻(若一个数字在另外一个数字相邻88个格子中的一个即认为这两个数字相邻),求取 ...

  6. PTA4题学习总结

    前言: 这是我20多年以来第一次写博客了,还是在学校里那可(牛)爱(逼)的Java老师的安(逼)慰(迫)下,含泪写下第一篇博客,大家应该都明白这种含泪写下的佳(废)作(品)是多么的动人的. 就不开玩笑 ...

  7. 无规矩不成方圆,聊一聊 Spring Boot 中 RESTful 接口设计规范

    在设计接口时,有很多因素要考虑,如接口的业务定位,接口的安全性,接口的可扩展性.接口的稳定性.接口的跨域性.接口的协议规则.接口的路径规则.接口单一原则.接口过滤和接口组合等诸多因素,本篇文章将简要分 ...

  8. Springboot自定义starter打印sql及其执行时间

    前面写到了通过实现mybatis提供的org.apache.ibatis.plugin.Interceptor接口实现了打印SQL执行时间,并格式化SQL及其参数,如果我们使用的是ssm还得再配置文件 ...

  9. csp-s模拟测试41「夜莺与玫瑰·玫瑰花精·影子」

    夜莺与玫瑰 题解 联赛$T1$莫比乌斯$\%\%\%$ $dead$  $line$是直线 首先横竖就是$n+m$这比较显然 枚举方向向量 首先我们枚举方向向量时只枚举右下方向,显然贡献$*2$就是所 ...

  10. Pandas高级教程之:处理缺失数据

    目录 简介 NaN的例子 整数类型的缺失值 Datetimes 类型的缺失值 None 和 np.nan 的转换 缺失值的计算 使用fillna填充NaN数据 使用dropna删除包含NA的数据 插值 ...