集合进阶(Map集合):

一、Map集合

1.1 Map概述体系

所有的Map集合有如下的特点:所有键是不允许重复的,值可以重复,键和值是一一对应的,每一个键只能找到自己对应的值。

写一个Map集合,保存几个键值对,体验一下Map集合的特点

复制代码
public class MapTest1 {
    public static void main(String[] args) {
        // Map<String, Integer> map = new HashMap<>(); // 一行经典代码。按照键: 无序,不重复,无索引。
        Map<String, Integer> map = new LinkedHashMap<>(); // 特点: 有序,不重复,无索引。
        map.put("手表", 100);
        map.put("手表", 220); // 后面重复的数据会覆盖前面的数据(键)
        map.put("手机", 2);
        map.put("Java", 2);
        map.put(null, null);
        System.out.println(map);
​
        Map<Integer, String> map1 = new TreeMap<>(); // 可排序,不重复,无索引
        map1.put(23, "Java");
        map1.put(23, "MySQL");
        map1.put(19, "李四");
        map1.put(20, "王五");
        System.out.println(map1);
    }
}

总结:

  1. Map集合是什么?什么时候可以考虑使用Map集合?

Map集合是键值对集合

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

  1. Map集合的实现类有哪些?各自的特点是?

HashMap: 元素按照键是无序,不重复,无索引,值不做要求。

LinkedHashMap: 元素按照键是有序,不重复,无索引,值不做要求。

TreeMap:元素按照建是排序,不重复,无索引的,值不做要求。

1.2 Map集合的常用方法

public class MapTest2 {

public static void main(String\[\] args) {

// 1.添加元素: 无序,不重复,无索引。

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 = {null=null, 手表=220, Java=2, 手机=2}

// 2.public int size():获取集合的大小

System.out.println(map.size());

// 3、public void clear():清空集合

//map.clear();

//System.out.println(map);

// 4.public boolean isEmpty(): 判断集合是否为空,为空返回true ,反之!

System.out.println(map.isEmpty());

// 5.public V get(Object key):根据键获取对应值

int v1 = map.get("手表");

System.out.println(v1);

System.out.println(map.get("手机")); // 2

System.out.println(map.get("张三")); // null

// 6. public V remove(Object key):根据键删除整个元素(删除键会返回键的值)

System.out.println(map.remove("手表"));

System.out.println(map);

// 7.public boolean containsKey(Object key): 判断是否包含某个键 ,包含返回true ,反之

System.out.println(map.containsKey("手表")); // false

System.out.println(map.containsKey("手机")); // true

System.out.println(map.containsKey("java")); // false

System.out.println(map.containsKey("Java")); // true

// 8.public boolean containsValue(Object value): 判断是否包含某个值。

System.out.println(map.containsValue(2)); // true

System.out.println(map.containsValue("2")); // false

// 9.public Set<K> keySet(): 获取Map集合的全部键。

Set<String> keys = map.keySet();

System.out.println(keys);

// 10.public Collection<V> values(); 获取Map集合的全部值。

Collection<Integer> values = map.values();

System.out.println(values);

// 11.把其他Map集合的数据倒入到自己集合中来。(拓展)

Map<String, Integer> map1 = new HashMap<>();

map1.put("java1", 10);

map1.put("java2", 20);

Map<String, Integer> map2 = new HashMap<>();

map2.put("java3", 10);

map2.put("java2", 222);

map1.putAll(map2); // putAll:把map2集合中的元素全部倒入一份到map1集合中去。

System.out.println(map1);

System.out.println(map2);

}

}

相关推荐
白鲸开源11 小时前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github
白鲸开源11 小时前
一文读懂DolphinScheduler插件机制:如何轻松扩展任务类型与数据源
java·架构·github
用户2986985301415 小时前
Java 实现 Word 文档文本查找与高亮标注
java·后端
宇宙之一粟16 小时前
乐企版式文件生成平台
java·后端·python
plainGeekDev17 小时前
MVC 写法 → MVVM
android·java·kotlin
SL_staff17 小时前
3周搭完MES系统:JVS低代码+JVS-IoT物联网的实战记录
java·前端·低代码
MacroZheng17 小时前
斩获20w star!Claude Code最强插件,AI编程必备!
java·人工智能·后端
唐青枫19 小时前
Java Spring WebFlux 实战指南:用 Mono、Flux 和 WebClient 写响应式接口
java·spring
小bo波1 天前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking1 天前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试