一,概述

java.util.Map(K,V)集合。
Map集合特点
1,Map集合是一个双列集合,一个元素包含两个值(一个key,一个value);
2,Map集合中的元素,key和value的数据类型可以一致,也可以不同;
3,Map集合中的元素,key是不允许重复的,value是可以重复的;
4,Map集合中的元素,key和value是一一对应的。

二,HashMap集合

java.util.HashMap<K,V>集合 implements Map<K ,V>接口。
HashMap集合特点
1,HashMap集合底层是哈希表:查询速度特别快。
JDK1.8之前:数组+单向链表;
JDK1.8之后:数组+单向链表/红黑树(链表长度超过8时)。
2,HashMap是一个无序集合,存储元素和取出元素顺序可能不一致。

三,LinkedHashMap集合

java.util.LinkedHashMap<K,V>集合 extends HashMap<K,V>集合。
LinkedHashMap特点:
1,LinkedHashMap底层是哈希表+链表(保证迭代顺序);
2,LinkedHashMap集合是一个有序集合,存储元素和取出元素顺序一致。

四,Map接口中常用方法

V put(K key,V value):把指定的键和指定的值添加到Map集合当中。
返回值:V
1,存储键值对时,key不重复,返回值V是null;
2,存储键值对时,key重复,会使用新的value替换map中重复的value,返回被替换的值。

V remove(Object key):把指定的键值对元素从map集合当中删除,返回被删除元素的值。
返回值:V
1,key存在,V返回被删除元素的值;
2,key不存在,返回null。

V get(Object key):根据指定的键,返回集合中对应的值。
返回值:V
1,key存在,返回value值;
2,key不存在,返回null;

boolean containKey(Object key):判断集合中是否包含指定的键,包含则返回true,不包含返回false。

import java.util.HashMap;

public class DemoHashMap {
    public static void main(String[] args) {
        demo1();
        demo2();
        demo3();
        demo4();

    }

    private static void demo4() {
        HashMap<String, Integer> map4 = new HashMap<>();
        map4.put("小海",171);
        map4.put("小军",175);
        map4.put("小鸿",171);
        boolean b1 = map4.containsKey("小红");
        System.out.println(b1); //false
        boolean b2 = map4.containsKey("小军");
        System.out.println(b2); //true
    }

    private static void demo3() {
        HashMap<String, Integer> map3 = new HashMap<>();
        map3.put("小海",171);
        map3.put("小军",175);
        map3.put("小鸿",171);
        Integer v2 = map3.get("小鸿");
        System.out.println(v2); //171
        Integer v3 = map3.get("小美");
        System.out.println(v3); //null
    }

    private static void demo2() {
        HashMap<String, Integer> map2 = new HashMap<>();
        map2.put("小海",171);
        map2.put("小军",175);
        map2.put("小鸿",171);
        System.out.println(map2); //{小海=171, 小军=175, 小鸿=171}
        Integer v1 = map2.remove("小军");
        System.out.println(v1); //175
        Integer v2 = map2.remove("小美");
        System.out.println(v2); //null

    }

    private static void demo1() {
        HashMap<String, String> map = new HashMap<>();
        String s1 = map.put("火箭", "哈登");
        System.out.println(s1); //null
        String s2 = map.put("湖人", "戴维斯");
        System.out.println(s2);//null
        String s3 = map.put("湖人", "詹姆斯");
        System.out.println(s3); //戴维斯
        System.out.println(map); //{湖人=詹姆斯, 火箭=哈登}
    }
}

五,Map集合遍历方式

1,通过键找值的方式
方法:set keySet():返回映射中包含键的set视图。
实现步骤:
(1),使用Map集合中的方法keySet(),把map集合中所有的key取出,存储到一个set集合当中;
(2),遍历set集合,获取map集合中每一个key;
(3),通过map集合中的方法get(key),通过key找value。

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

public class DemoKeySet {
    public static void main(String[] args) {
        demo1();
    }

    private static void demo1() {
        Map<String,Integer> map = new HashMap<>();
        map.put("赵丽颖",163);
        map.put("杨幂",165);
        map.put("迪丽热巴",168);

        Set<String> set1 = map.keySet();
        Iterator<String> it = set1.iterator();
        while(it.hasNext()){
            String key = it.next();
            Integer value = map.get(key);
            System.out.print(key+"="+value+" "); //赵丽颖=163 迪丽热巴=168 杨幂=165
        }

        for (String key : map.keySet()) {
            Integer value = map.get(key);
            System.out.print(key+"="+value+" "); //赵丽颖=163 迪丽热巴=168 杨幂=165
        }
    }
}

2,Map.Entry<K,V>:在Map接口当中有一个内部接口Entry,作用是当Map集合一创建,那么就会在Map集合当中创建一个Entry对象,用来记录键和值(键值对对象键和值的映射关系)。
方法:Set<Map.Entry<K,V>> entrySet():返回此映射中包含的映射关系的Set视图。
实现步骤:
(1),使用Map集合当中的方法entrySet(),把Map集合当中多个entry对象取出来,存储到一个Set集合当中。
(2),遍历Set集合,取出每一个entry对象;
(3),使用entry对象中的方法getKey()和getValue()获取键和值。

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

public class DemoEntrySet {
    public static void main(String[] args) {
        Map<String,Integer> map = new HashMap<>();
        map.put("赵丽颖",163);
        map.put("杨幂",165);
        map.put("迪丽热巴",168);

        Set<Map.Entry<String, Integer>> set = map.entrySet();
        for (Map.Entry<String, Integer> setobj : set) {
            String key = setobj.getKey();
            Integer value = setobj.getValue();
            System.out.print(key+"="+value+" "); //赵丽颖=163 迪丽热巴=168 杨幂=165
        }

        Iterator<Map.Entry<String, Integer>> it = set.iterator();
        while (it.hasNext()){
            Map.Entry<String, Integer> obj = it.next();
            String key = obj.getKey();
            Integer value = obj.getValue();
            System.out.print(key+"="+value+" ");//赵丽颖=163 迪丽热巴=168 杨幂=165
        }
    }
}

六,HashMap存储自定义类型

Map集合须保证key是唯一的:
作为key元素,必须重写hashCode()方法和equals方法,以保证key唯一。
存储自定义类型:
1,key:String类,已经重写了hashCode()方法和equals()方法,可以保证key的唯一性。
value:Person类型,value可重复(同名同年龄视为同一个)。
2,key:Person类,须自己重写hashCode()方法和equals()方法,以保证key唯一。
values:String类,可以重复。

import java.util.Objects;

public class Person {
    private String name;
    private int age;

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Person person = (Person) o;
        return age == person.age &&
                Objects.equals(name, person.name);
    }

    @Override
    public int hashCode() {

        return Objects.hash(name, age);
    }


public class DemoHashMapSavePerson {
    public static void main(String[] args) {
        demo1();
        demo2();
    }

    private static void demo2() {
        HashMap<Person,String> map = new HashMap<>();
        map.put(new Person("小虎",18),"广东");
        map.put(new Person("小浩",20),"福建");
        map.put(new Person("小谷",19),"广西");
        map.put(new Person("小虎",18),"湖南");
        Set<Map.Entry<Person, String>> set = map.entrySet();
        Iterator<Map.Entry<Person, String>> it = set.iterator();
        while(it.hasNext()){
            Map.Entry<Person, String> entry = it.next();
            Person key = entry.getKey();
            String value = entry.getValue();
            System.out.println(key+":"+value);
            /*未重写hashCode()和equals()方法之前:
            Person{name='小虎', age=18}:湖南
            Person{name='小浩', age=20}:福建
            Person{name='小虎', age=18}:广东
            Person{name='小谷', age=19}:广西
            之后:
            Person{name='小谷', age=19}:广西
            Person{name='小虎', age=18}:湖南
            Person{name='小浩', age=20}:福建
            */
        }
    }

    private static void demo1() {
        HashMap<String,Person> map = new HashMap<>();
        map.put("广东",new Person("小虎",18));
        map.put("福建",new Person("小浩",20));
        map.put("广西",new Person("小谷",19));
        map.put("广东",new Person("小寻",15));
        Set<String> keys = map.keySet();
        for (String key : keys) {
            Person value = map.get(key);
            System.out.println(key+"-->"+value);
        }
        /*
        福建-->Person{name='小浩', age=20}
        广东-->Person{name='小寻', age=15}
        广西-->Person{name='小谷', age=19}
        */
    }
}