Map集合

概述

  • Map集合是双列集合,一个元素包含两个值(keyvalue

  • Map集合中的元素,key和value数据类型可以相同也可以不同

  • Map集合中的元素,key不允许重复,value可以重复

  • key和value是一一对应的

Map公用方法

public V put(K key, V value):把指定的键与指定的值添加到Map集合中,key不重复时,返回值V为null;key重复的时候,会使用新的value替换Map中的value,返回被替换的value值

public V remove(Object key):把指定的键所对应的键值对元素在Map集合中删除,返回被删除元素

public V get(Object key):根据指定的键,在Map集合中获取对应的值

boolean containsKey(Object key):判断集合中是否包含指定的键

public Set keySet():获取Map集合中所有的键,储存到Set集合中

public Set<Map.Entry<K, V>> entrySet():获取到Map集合中所有键值对对象的集合(Set集合)

遍历Map集合

  • 键找值的方法

    • 使用Map集合中 keySet()方法将集合中的key取出,储存到Set集合中

    • 利用遍历器或增强for循环遍历Set集合,获取每一个key

    • 使用Map集合中get(Object key)方法,通过key获取value

      public class IteratorDemo01 {
          public static void main(String[] args) {
              Map<String, Integer> map = new HashMap<>();
              map.put("garen", 100);
              map.put("temmo", 300);
              map.put("angel", 100);
      
              Set<String> key = map.keySet();
              //迭代器的方法
              Iterator<String> iterator = key.iterator();
              while (iterator.hasNext()){
                  String next = iterator.next();
                  Integer value = map.get(next);
                  System.out.println(next+"="+value);
              }
              System.out.println("=================");
              //增强for循环方法
              for (String s : map.keySet()) {
                  Integer value = map.get(s);
                  System.out.println(s+"="+value);
              }
          }
      }
      
  • 键值对方法

    • 使用Map集合中 entrySet()方法将集合中的Entry对象取出,储存到Set集合中

    • 利用遍历器或增强for循环遍历Set集合,获取每一个Entry对象

    • 使用Entry对象中的方法getKey()和getValue()方法获取键和值

      public class IteratorDemo02 {
          public static void main(String[] args) {
              Map<String, Integer> map = new HashMap<>();
              map.put("garen", 100);
              map.put("temmo", 300);
              map.put("angel", 100);
      
              Set<Map.Entry<String, Integer>> entry = map.entrySet();
              //迭代器方法
              Iterator<Map.Entry<String, Integer>> iterator = entry.iterator();
              while (iterator.hasNext()){
                  Map.Entry<String, Integer> next = iterator.next();
                  String key = next.getKey();
                  Integer value = next.getValue();
                  System.out.println(key+"="+value);
              }
              System.out.println("=================");
              //增强for循环方法
              for (Map.Entry<String, Integer> m :entry) {
                  String key = m.getKey();
                  Integer value = m.getValue();
                  System.out.println(key+"="+value);
              }
          }
      }
      

HashMap集合

  • HashMap集合底层是哈希表(数组+单向链表/红黑树),查询速度快

  • HashMap集合是一个无序的集合,存储元素和取出元素的顺序可能不一致

  • HashMap集合存储自定义键值,key元素的hashCode和equals方法需要覆盖重写

    public class Hero {
        private String name;
        float hp;
    
        public Hero(String name, float hp) {
            this.name = name;
            this.hp = hp;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public float getHp() {
            return hp;
        }
    
        public void setHp(float hp) {
            this.hp = hp;
        }
    
        @Override
        public String toString() {
            return "Hero{" +
                    "name='" + name + '\'' +
                    ", hp=" + hp +
                    '}';
        }
    
        //覆盖重写hashCode和equals方法
        @Override
        public boolean equals(Object o) {
            if (this == o) return true;
            if (o == null || getClass() != o.getClass()) return false;
            Hero hero = (Hero) o;
            return Float.compare(hero.hp, hp) == 0 &&
                    Objects.equals(name, hero.name);
        }
    
        @Override
        public int hashCode() {
            return Objects.hash(name, hp);
        }
    }
    
    /////////////////////////////////////////////////////
    
    import java.util.HashMap;
    import java.util.Map;
    import java.util.Set;
    
    public class HashMapDemo01 {
        public static void main(String[] args) {
            HashMap<Hero, String> hashMap = new HashMap<>();
            //key不能重复,value可以重复
            hashMap.put(new Hero("garen", 100), "Hero01");
            hashMap.put(new Hero("temmo", 200), "Hero01");
            hashMap.put(new Hero("angel", 300), "Hero02");
            hashMap.put(new Hero("garen", 100), "ADHero");
    
            Set<Hero> set = hashMap.keySet();
            for (Hero key : set) {
                String value = hashMap.get(key);
                System.out.println(key+"-->"+value);
            }
            System.out.println("============================");
            Set<Map.Entry<Hero, String>> entrySet = hashMap.entrySet();
            for (Map.Entry<Hero, String> entry : entrySet) {
                Hero key = entry.getKey();
                String value = entry.getValue();
                System.out.println(key+"-->"+value);
            }
        }
    }
    

LinkedHashMap集合

  • LinkedHashMap集合底层是哈希表+链表(保证迭代的顺序)
  • LinkedHashMap集合是一个有序的集合,存储元素和取出元素的顺序是一致的

静态方法of

  • List接口,Set接口,Map接口内有静态方法of,可以给集合一次性添加多个元素

    List<E> list = List.of(E...);

    Set<E> set = Set.of(E...);

    Map<E> map = Map.of(E...);

  • of方法只适用于List接口,Set接口和Map接口,不适用于它们的实现类

  • of方法返回值是一个不能改变的集合,集合不能再使用add,put等方法添加元素,否则会抛出异常

  • Set接口和Map接口在调用of方法时不能有重复的元素,否则会抛出异常

posted @ 2020-06-30 20:18  搁浅Lee  阅读(316)  评论(0编辑  收藏  举报