集合进阶(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);

}

}

相关推荐
吴声子夜歌1 小时前
Java——文件和目录操作
java·文件·目录
吴声子夜歌1 小时前
Java——随机
java·random·随机
aaaak_1 小时前
PDD 直播间 评论 , wss hex Protobuf 解析流程分析学习
java·前端·学习
小雅痞1 小时前
[Java][Leetcode simple] 205. 同构字符串
java·算法·leetcode
多加点辣也没关系2 小时前
设计模式-策略模式
java·设计模式·策略模式
2601_953660372 小时前
Java Map集合详解与实战
java·开发语言·python
星晨羽2 小时前
java通过共享目录协议下载文件到本地
java
YuanDaima20482 小时前
云计算基础与容器技术演进
java·服务器·人工智能·python·深度学习·云计算·个人开发
java1234_小锋2 小时前
SpringBoot可以同时处理多少请求?
java·spring boot·后端