Java集合Map

简介: Java集合Map

1 Map集合概述和特点

Map集合概述

interface Map<K,V> K:键的类型;V:值的类型

Map集合的特点

键值对映射关系

一个键对应一个值

键不能重复,值可以重复

元素存取无序

Map集合的基本使用

public class MapDemo01 {
    public static void main(String[] args) {
//创建集合对象
        Map<String,String> map = new HashMap<String,String>();
//V put(K key, V value) 将指定的值与该映射中的指定键相关联
        map.put("itheima001","林青霞");
        map.put("itheima002","张曼玉");
        map.put("itheima003","王祖贤");
        map.put("itheima003","柳岩");
//输出集合对象
        System.out.println(map);
    }
}
2 

Map集合的基本功能

方法介绍

add()和put()方法都是集合框架中的添加元素的方法。

但是put()方法应用于map集合中,add()方法应用于collection集合中。

二者的主要区别是:返回值类型不一样。

add()放回布尔(boolean)类型。因为像Set集合中不允许添加重复的元素。当HashSet调用add()方法时,如果返回false,表示添加不成功。

put()的使用是:添加时出现相同的键,那么后添加的值会替换(覆盖)掉此键对应的原来的值。并返回此键对应的原来的值。

示例代码

public class MapDemo02 {
    public static void main(String[] args) {
//创建集合对象
        Map<String,String> map = new HashMap<String,String>();
//V put(K key,V value):添加元素
        map.put("张无忌","赵敏");
        map.put("郭靖","黄蓉");
        map.put("杨过","小龙女");
//V remove(Object key):根据键删除键值对元素
// System.out.println(map.remove("郭靖"));
// System.out.println(map.remove("郭襄"));
//void clear():移除所有的键值对元素
// map.clear();
//boolean containsKey(Object key):判断集合是否包含指定的键
// System.out.println(map.containsKey("郭靖"));
// System.out.println(map.containsKey("郭襄"));
//boolean isEmpty():判断集合是否为空
// System.out.println(map.isEmpty());
//int size():集合的长度,也就是集合中键值对的个数
        System.out.println(map.size());
//输出集合对象
        System.out.println(map);
    }
}

3 Map集合的获取功能

方法介绍

示例代码

public class MapDemo03 {
    public static void main(String[] args) {
//创建集合对象
        Map<String, String> map = new HashMap<String, String>();
//添加元素
        map.put("张无忌", "赵敏");
        map.put("郭靖", "黄蓉");
        map.put("杨过", "小龙女");
//V get(Object key):根据键获取值
// System.out.println(map.get("张无忌"));
// System.out.println(map.get("张三丰"));
//Set<K> keySet():获取所有键的集合
// Set<String> keySet = map.keySet();
// for(String key : keySet) {
// System.out.println(key);
// }
//Collection<V> values():获取所有值的集合
        Collection<String> values = map.values();
        for(String value : values) {
            System.out.println(value);
        }
    }
}

4 Map集合的遍历(方式1)

方式1:

方式2:

方式3:

方式4:

遍历思路

我们刚才存储的元素都是成对出现的,所以我们把 Map 看成是一个夫妻对的集合把所有的丈夫给集中起来遍历丈夫的集合,获取到每一个丈夫根据丈夫去找对应的妻子步骤分析获取所有键的集合。用keySet() 方法实现遍历键的集合,获取到每一个键。用增强for 实现根据键去找值。用get(Object key) 方法实现

代码实现

public class MapDemo01 {
    public static void main(String[] args) {
//创建集合对象
        Map<String, String> map = new HashMap<String, String>();
//添加元素
        map.put("张无忌", "赵敏");
        map.put("郭靖", "黄蓉");
        map.put("杨过", "小龙女");
//获取所有键的集合。用keySet()方法实现
        Set<String> keySet = map.keySet();
//遍历键的集合,获取到每一个键。用增强for实现
        for (String key : keySet) {
//根据键去找值。用get(Object key)方法实现
            String value = map.get(key);
            System.out.println(key + "," + value);
        }
    }
}

5 Map集合的遍历(方式2)

遍历思路

我们刚才存储的元素都是成对出现的,所以我们把 Map 看成是一个夫妻对的集合获取所有结婚证的集合遍历结婚证的集合,得到每一个结婚证根据结婚证获取丈夫和妻子步骤分析获取所有键值对对象的集合Set> entrySet():获取所有键值对对象的集合遍历键值对对象的集合,得到每一个键值对对象用增强for 实现,得到每一个 Map.Entry根据键值对对象获取键和值用getKey() 得到键用getValue() 得到值

代码实现

public class MapDemo02 {
    public static void main(String[] args) {
//创建集合对象
        Map<String, String> map = new HashMap<String, String>();
//添加元素
        map.put("张无忌", "赵敏");
        map.put("郭靖", "黄蓉");
        map.put("杨过", "小龙女");
//获取所有键值对对象的集合
        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.println(key + "," + value);
        }
    }
} 

6 Map集合的案例

6.1 HashMap集合练习之键是String值是Student

案例需求

创建一个 HashMap 集合,键是学号 (String) ,值是学生对象 (Student) 。存储三个键值对元素,并遍历

代码实现

学生类

public class Student {
    private String name;
    private int age;
    public Student() {
    }
    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
}

测试类

/*
需求:
创建一个HashMap集合,键是学号(String),值是学生对象(Student)。存储三个键值对
元素,并遍历
思路:
1:定义学生类
2:创建HashMap集合对象
3:创建学生对象
4:把学生添加到集合
5:遍历集合
方式1:键找值
方式2:键值对对象找键和值
*/
public class HashMapDemo {
    public static void main(String[] args) {
//创建HashMap集合对象
        HashMap<String, Student> hm = new HashMap<String, Student>();
//创建学生对象
        Student s1 = new Student("林青霞", 30);
        Student s2 = new Student("张曼玉", 35);
        Student s3 = new Student("王祖贤", 33);
//把学生添加到集合
        hm.put("itheima001", s1);
        hm.put("itheima002", s2);
        hm.put("itheima003", s3);
//方式1:键找值
        Set<String> keySet = hm.keySet();
        for (String key : keySet) {
            Student value = hm.get(key);
            System.out.println(key + "," + value.getName() + "," +
                    value.getAge());
        }
        System.out.println("--------");
//方式2:键值对对象找键和值
        Set<Map.Entry<String, Student>> entrySet = hm.entrySet();
        for (Map.Entry<String, Student> me : entrySet) {
            String key = me.getKey();
            Student value = me.getValue();
            System.out.println(key + "," + value.getName() + "," +
                    value.getAge());
        }
    }
}

6.2 HashMap集合练习之键是Student值是String

案例需求

创建一个 HashMap 集合,键是学生对象 (Student) ,值是居住地 (String) 。存储多个元素,并遍历。

要求保证键的唯一性:如果学生对象的成员变量值相同,我们就认为是同一个对象

代码实现

学生类

public class Student {
    private String name;
    private int age;
    public Student() {
    }
    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Student student = (Student) o;
        if (age != student.age) return false;
        return name != null ? name.equals(student.name) : student.name ==
                null;
    }
    @Override
    public int hashCode() {
        int result = name != null ? name.hashCode() : 0;
        result = 31 * result + age;
        return result;
    }
}

测试类

public class HashMapDemo {
    public static void main(String[] args) {
//创建HashMap集合对象
        HashMap<Student, String> hm = new HashMap<Student, String>();
//创建学生对象
        Student s1 = new Student("林青霞", 30);
        Student s2 = new Student("张曼玉", 35);
        Student s3 = new Student("王祖贤", 33);
        Student s4 = new Student("王祖贤", 33);
//把学生添加到集合
        hm.put(s1, "西安");
        hm.put(s2, "武汉");
        hm.put(s3, "郑州");
        hm.put(s4, "北京");
//遍历集合
        Set<Student> keySet = hm.keySet();
        for (Student key : keySet) {
            String value = hm.get(key);
            System.out.println(key.getName() + "," + key.getAge() + "," +
                    value);
        }
    }
}

6.3 集合嵌套之ArrayList嵌套HashMap

案例需求

创建一个 ArrayList 集合,存储三个元素,每一个元素都是 HashMap

每一个 HashMap 的键和值都是 String ,并遍历。

代码实现

public class ArrayListIncludeHashMapDemo {
    public static void main(String[] args) {
//创建ArrayList集合
        ArrayList<HashMap<String, String>> array = new
                ArrayList<HashMap<String, String>>();
//创建HashMap集合,并添加键值对元素
        HashMap<String, String> hm1 = new HashMap<String, String>();
        hm1.put("孙策", "大乔");
        hm1.put("周瑜", "小乔");
//把HashMap作为元素添加到ArrayList集合
        array.add(hm1);
        HashMap<String, String> hm2 = new HashMap<String, String>();
        hm2.put("郭靖", "黄蓉");
        hm2.put("杨过", "小龙女");
//把HashMap作为元素添加到ArrayList集合
        array.add(hm2);
        HashMap<String, String> hm3 = new HashMap<String, String>();
        hm3.put("令狐冲", "任盈盈");
        hm3.put("林平之", "岳灵珊");
//把HashMap作为元素添加到ArrayList集合
        array.add(hm3);
//遍历ArrayList集合
        for (HashMap<String, String> hm : array) {
            Set<String> keySet = hm.keySet();
            for (String key : keySet) {
                String value = hm.get(key);
                System.out.println(key + "," + value);
            }
        }
    }
}

6.4 集合嵌套之HashMap嵌套ArrayList

案例需求

创建一个 HashMap 集合,存储三个键值对元素,每一个键值对元素的键是 String ,值是 ArrayList

每一个 ArrayList 的元素是 String ,并遍历。

代码实现

public class HashMapIncludeArrayListDemo {
    public static void main(String[] args) {
//创建HashMap集合
        HashMap<String, ArrayList<String>> hm = new HashMap<String,
                ArrayList<String>>();
//创建ArrayList集合,并添加元素
        ArrayList<String> sgyy = new ArrayList<String>();
        sgyy.add("诸葛亮");
        sgyy.add("赵云");
//把ArrayList作为元素添加到HashMap集合
        hm.put("三国演义",sgyy);
        ArrayList<String> xyj = new ArrayList<String>();
        xyj.add("唐僧");
        xyj.add("孙悟空");
//把ArrayList作为元素添加到HashMap集合
        hm.put("西游记",xyj);
        ArrayList<String> shz = new ArrayList<String>();
        shz.add("武松");
        shz.add("鲁智深");
//把ArrayList作为元素添加到HashMap集合
        hm.put("水浒传",shz);
//遍历HashMap集合
        Set<String> keySet = hm.keySet();
        for(String key : keySet) {
            System.out.println(key);
            ArrayList<String> value = hm.get(key);
            for(String s : value) {
                System.out.println("\t" + s);
            }
        }
    }
}

6.5 统计字符串中每个字符出现的次数

案例需求

键盘录入一个字符串,要求统计字符串中每个字符串出现的次数。

举例:键盘录入 “aababcabcdabcde” 在控制台输出: “a(5)b(4)c(3)d(2)e(1)”

代码实现

public class HashMapDemo {
    public static void main(String[] args) {
//键盘录入一个字符串
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入一个字符串:");
        String line = sc.nextLine();
//创建HashMap集合,键是Character,值是Integer
// HashMap<Character, Integer> hm = new HashMap<Character, Integer>();
        TreeMap<Character, Integer> hm = new TreeMap<Character, Integer>();
//遍历字符串,得到每一个字符
        for (int i = 0; i < line.length(); i++) {
            char key = line.charAt(i);
//拿得到的每一个字符作为键到HashMap集合中去找对应的值,看其返回值
            Integer value = hm.get(key);
            if (value == null) {
//如果返回值是null:说明该字符在HashMap集合中不存在,就把该字符作为键,1
                作为值存储
                hm.put(key,1);
            } else {
//如果返回值不是null:说明该字符在HashMap集合中存在,把该值加1,然后重新
                存储该字符和对应的值
                value++;
                hm.put(key,value);
            }
        }
//遍历HashMap集合,得到键和值,按照要求进行拼接
        StringBuilder sb = new StringBuilder();
        Set<Character> keySet = hm.keySet();
        for(Character key : keySet) {
            Integer value = hm.get(key);
            sb.append(key).append("(").append(value).append(")");
        }
        String result = sb.toString();
//输出结果
        System.out.println(result);
    }
} 

7 拓展面试知识

7.1 Map的实现类和作用

保存商品信息,也可以统计商品数量.

7.2 HashMap怎么做到对象内容相同key去重

当存储一个元素先比较的是hashCode看看地址值是否相同,至于地址怎么算不用管,然后在比较equals的内容,如果都一样就挂不上去,比较的是地址和内容.这里是0,只是举例其实直接生成代码即可.

7.3 hashMap和hashTable的区别

7.4 二叉查找树(有序、左小右大)

7.5 Map顺序读取

大家都知道map中的key是一个set集合,但是我们在自己把元素put进map,输出map集合的时候里面的key元素并不是按我们插进去的顺序来输出的。


简单的做法是:


采用LinkedHashMap。它内部有一个链表,保持插入的顺序。迭代的时候,也是按照插入顺序迭代,而且迭代比HashMap快。

目录
相关文章
|
2月前
|
Java 大数据 API
Java Stream API:现代集合处理与函数式编程
Java Stream API:现代集合处理与函数式编程
229 100
|
2月前
|
Java API 数据处理
Java Stream API:现代集合处理新方式
Java Stream API:现代集合处理新方式
261 101
|
2月前
|
算法 Java
50道java集合面试题
50道 java 集合面试题
|
1月前
|
存储 算法 安全
Java集合框架:理解类型多样性与限制
总之,在 Java 题材中正确地应对多样化与约束条件要求开发人员深入理解面向对象原则、范式编程思想以及JVM工作机理等核心知识点。通过精心设计与周密规划能够有效地利用 Java 高级特征打造出既健壮又灵活易维护系统软件产品。
68 7
|
4月前
|
Oracle Java 关系型数据库
掌握Java Stream API:高效集合处理的利器
掌握Java Stream API:高效集合处理的利器
381 80
|
4月前
|
安全 Java API
Java 8 Stream API:高效集合处理的利器
Java 8 Stream API:高效集合处理的利器
281 83
|
2月前
|
存储 Java Go
对比Java学习Go——函数、集合和OOP
Go语言的函数支持声明与调用,具备多返回值、命名返回值等特性,结合`func`关键字与类型后置语法,使函数定义简洁直观。函数可作为一等公民传递、赋值或作为参数,支持匿名函数与闭包。Go通过组合与接口实现面向对象编程,结构体定义数据,方法定义行为,接口实现多态,体现了Go语言的简洁与高效设计。
|
3月前
|
存储 缓存 安全
Java集合框架(二):Set接口与哈希表原理
本文深入解析Java中Set集合的工作原理及其实现机制,涵盖HashSet、LinkedHashSet和TreeSet三大实现类。从Set接口的特性出发,对比List理解去重机制,并详解哈希表原理、hashCode与equals方法的作用。进一步剖析HashSet的底层HashMap实现、LinkedHashSet的双向链表维护顺序特性,以及TreeSet基于红黑树的排序功能。文章还包含性能对比、自定义对象去重、集合运算实战和线程安全方案,帮助读者全面掌握Set的应用与选择策略。
236 23
|
3月前
|
存储 缓存 安全
Java集合框架(三):Map体系与ConcurrentHashMap
本文深入解析Java中Map接口体系及其实现类,包括HashMap、ConcurrentHashMap等的工作原理与线程安全机制。内容涵盖哈希冲突解决、扩容策略、并发优化,以及不同Map实现的适用场景,助你掌握高并发编程核心技巧。
|
3月前
|
安全 Java 开发者
Java集合框架:详解Deque接口的栈操作方法全集
理解和掌握这些方法对于实现像浏览器后退功能这样的栈操作来说至关重要,它们能够帮助开发者编写既高效又稳定的应用程序。此外,在多线程环境中想保证线程安全,可以考虑使用ConcurrentLinkedDeque,它是Deque的线程安全版本,尽管它并未直接实现栈操作的方法,但是Deque的接口方法可以相对应地使用。
224 12