【Java】Map集合概述

一、前言


map集合是我们常使用的集合,了解和使用map集合是必要的


二、Map介绍


  基本形式:   public interface  Map<K,V>



Map是一个接口,我们不能直接创建对象,可以通过多态的形式创建对象,Map中有两个


参数,一个是K表示键,一个是V表示值,且一个键有且对应一个值,Map中不能包含重复的


键,若是有重复的键添加,则会以最后一次的键为准,而其他的键会被覆盖。集合都在


java.util包下,所以需要导包。


具体实现常用的一般有两种,一是HashMap,另一个是TreeMap


import java.util.HashMap;
import java.util.Map;
 
public class MapTest {
    public static void main(String[] args) {
        Map<String,String> map=new HashMap<>();
        map.put("2001", "张三");
        map.put("2002", "张三");
        map.put("2003", "李四");
      map.put("2003", "王五");//键重复,会覆盖上一个,留下最新的
        System.out.println(map);//{2003=王五, 2002=张三, 2001=张三}
    }
}


由上可知,map中的键是不能重复的,而值是可以重复的可以直接通过输出对象来得到


集合的内容,说明此集合内重写了toString方法。


三、Map的基本功能


【Java】Map集合概述


 这些功能是常见的,掌握这些即可


Map功能演示:


import java.util.HashMap;
 import java.util.Map;
 
public class MapTest {
    public static void main(String[] args) {
        //创建Map集合对象
        Map<String,String> map=new HashMap<>();
        //增加元素
        map.put("2001", "张三");
        map.put("2002", "李四");
        map.put("2003", "王五");
        System.out.println(map);//{2003=王五, 2002=李四, 2001=张三}
        //根据键删除元素
        //  map.remove("2001");
        //System.out.println(map);//{2003=王五, 2002=李四}
        //判断集合中是否包含指定的键返回boolean类型
        System.out.println(map.containsKey("2001"));//true
        System.out.println(map.containsKey("2004"));//false
        //判断集合中是否包含指定的值返回boolean类型
        System.out.println(map.containsValue("张三"));//true
        System.out.println(map.containsValue("赵六"));//false
        //判断集合是否为空返回boolean类型
        System.out.println(map.isEmpty());//false
        //得到集合的长度
        System.out.println(map.size());//3
        //清除所有键值对
        map.clear();
        System.out.println(map.isEmpty());//true,为空了
 
    }
}


四、 Map集合的获取功能


【Java】Map集合概述


 此方法多是用在遍历集合时,前三种比较常用也比较好记。


Map遍历演示:


import java.util.HashMap;
import java.util.Map;
import java.util.Set;
 
public class Maptest2 {
    public static void main(String[] args) {
        Map<String, String> map = new HashMap<>();
        map.put("2001", "张三");
        map.put("2002", "李四");
        map.put("2003", "王五");
       //遍历集合
        //方式1:
        // 由键找值,创建键的集合
        Set<String>  keySet=map.keySet();
        //遍历键的集合,得到每一个键
        for (String key:keySet){
            //由键找值
            String value=map.get(key);
            //输出键和值
            System.out.print(key+" "+value+", ");
        }
        System.out.println("\n------------");
 
        //方式2:
        //获取所有键值对的集合
        Set<Map.Entry<String,String>>  entrySet  =map.entrySet();
        //遍历键值对集合
        for (Map.Entry<String,String> me:entrySet){
            //分别得到键和值
            String key=me.getKey();
            String value=me.getValue();
            System.out.print(key+" "+value+", ");
        }
    }
}


如图:


【Java】Map集合概述


上一篇:[学习报告]《LeetCode零基础指南》(第六讲) C排序API


下一篇:数据结构与算法