JavaSE——集合框架二(3/6)-Map系列集合:概述、常用方法(认识Map集合,在什么情形下使用,Map集合体系,Map集合体系的特点)

简介: JavaSE——集合框架二(3/6)-Map系列集合:概述、常用方法(认识Map集合,在什么情形下使用,Map集合体系,Map集合体系的特点)

Map集合

概述

认识Map集合

  • Map集合称为双列集合,格式:{key1=value1,key2=value2,key3=value3,...),一次需要存一对数据做为一个元素
  • Map集合的每个元素“key=value”称为一个键值对/键值对对象/一个Entry对象,Map集合也被叫做“键值对集合”
  • Map集合的所有键是不允许重复的,但值可以重复,键和值是一一对应的,每一个键只能找到自己对应的值

在什么情形下使用

  • 需要存储一一对应的数据时,就可以考虑使用Map集合来做。

例如在购物车中,每一件商品就是一个键,商品的购买数量就是对应的值;


{ 商品1 = 2,商品2 = 3,商品3 = 2,商品4 = 3 },就代表着商品1购买了两件,商品2购买了三件依此类推。


Map集合体系

Map集合体系的特点

注意:Map系列集合的特点都是由键决定的,值只是一个附属品,值是不做要求的。

  • HashMap(由键决定特点):无序、不重复、无索引;(用的最多)
  • LinkedHashMap(由键决定特点):由键决定的特点:有序、不重复、无索引。
  • TreeMap(由键决定特点):按照大小默认升序排序、不重复、无索引。

代码演示

import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.TreeMap;
 
public class MapTest1 {
    public static void main(String[] args){
        Map<String,Integer> map1 = new HashMap<>();  //一行经典代码。  按照键 无序,不重复,无索引
        Map<String,Integer> map2 = new LinkedHashMap<>();   //有序,不重复,无索引
        map1.put("手表",100);
        map1.put("手表",220);
        map1.put("手机",2);
        map1.put("Java",2);
        map1.put(null,null);
        map2.put("手表",100);
        map2.put("手表",220);
        map2.put("手机",2);
        map2.put("Java",2);
        map2.put(null,null);
        System.out.println("(HashMap)       map1:" + map1);
        System.out.println("(LinkHashMap)   map2:" + map2);
 
        Map<Integer,String> map3 = new TreeMap<>(); //可排序,不重复,无索引
        map3.put(23,"Java");
        map3.put(23,"MySQL");
        map3.put(19,"李四");
        map3.put(20,"王五");
        System.out.println("(TreeMap)       map3:" + map3);
 
    }
}

运行结果:

常用方法

为什么要先学习Map的常用方法?

  • 与Collection集合一样,Map是双列集合的祖宗,它的功能是全部双列集合都可以继承过来使用的。

图片.png

添加元素 (无序,不重复,无索引)

import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
 
public class MapTest2 {
    public static void main(String[] args) {
        Map<String,Integer> map = new HashMap<>();  
        map.put("手表",100);
        map.put("手表",220);
        map.put("手机",2);
        map.put("Java",2);
        map.put(null,null);
        System.out.println(map);
    }
}

运行结果:


获取集合的大小&清空集合&判断集合是否为空


运行结果:


根据键获取对应值&根据键删除整个元素(删除键会返回键的值)


运行结果:


判断是否包含某个键&判断是否包含某个值


运行结果:


获取Map集合的全部值&把其他Map集合的数据倒入自己集合中来


运行结果:



END



目录
相关文章
|
1月前
|
存储 安全 Java
java集合框架及其特点(List、Set、Queue、Map)
java集合框架及其特点(List、Set、Queue、Map)
|
1月前
Map集合的简述
Map集合的简述
|
1月前
|
存储 Java
从零开始学习 Java:简单易懂的入门指南之Map集合(二十三)
从零开始学习 Java:简单易懂的入门指南之Map集合(二十三)
|
2天前
|
Dart
Dart之集合详解(List、Set、Map)
Dart之集合详解(List、Set、Map)
9 1
|
8天前
|
存储 JavaScript 前端开发
JavaScript进阶-Map与Set集合
【6月更文挑战第20天】JavaScript的ES6引入了`Map`和`Set`,它们是高效处理集合数据的工具。`Map`允许任何类型的键,提供唯一键值对;`Set`存储唯一值。使用`Map`时,注意键可以非字符串,用`has`检查键存在。`Set`常用于数组去重,如`[...new Set(array)]`。了解它们的高级应用,如结构转换和高效查询,能提升代码质量。别忘了`WeakMap`用于弱引用键,防止内存泄漏。实践使用以加深理解。
|
2天前
|
存储 消息中间件 算法
Java中的集合框架详解:List、Set、Map的使用场景
Java中的集合框架详解:List、Set、Map的使用场景
|
4天前
|
缓存 Java 测试技术
探讨Java中遍历Map集合的最快方式
探讨Java中遍历Map集合的最快方式
7 1
|
17天前
|
存储 缓存 Java
Java遍历Map集合的方法
在Java中,遍历Map集合主要有四种方式:1) 使用`keySet()`遍历keys并用`get()`获取values;2) 使用`entrySet()`直接遍历键值对,效率较高;3) 通过`Iterator`遍历,适合在遍历中删除元素;4) Java 8及以上版本可用`forEach`和Lambda表达式,简洁易读。`entrySet()`通常性能最佳,而遍历方式的选择应考虑代码可读性和数据量。
29 0
|
16天前
|
存储 安全 Java
Java集合详解:Set, Map, Vector, List的对比与联系
Java集合框架核心包括List、Set、Map和Vector。List允许重复元素,如ArrayList(适合读取)和LinkedList(适合插入删除)。Set不允许重复,有HashSet(无序)和TreeSet(排序)。Map存储键值对,HashMap(无序)和TreeMap(排序)。Vector是线程安全的ArrayList替代品,但在多线程环境下使用。选择集合类型应根据应用场景,如有序、无序、键值对需求及线程安全考虑。
|
1天前
|
存储 API Kotlin
Kotlin中的Map集合
Kotlin中的Map集合
5 0