zoukankan      html  css  js  c++  java
  • Map集合

     

    》为什么要使用Map集合?

    不便利集合所有元素进行对象属性值的判断,就可以根据键取到对象,这是Collection集合办不到的,Map可以轻易做到。

    》Map集合的特点?

    将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。

    》Map集合和Collection集合的区别?

    Map集合存储元素是成对出现的,Map集合的键是唯一的,值是可重复的。可以把这个理解为:夫妻对

    Collection集合存储元素是单独出现的,Collection的儿子Set是唯一的,List是可重复的。可以把这个理解为:光棍

    》注意:  Map集合的数据结构值针对键有效,跟值无关

        Collection集合的数据结构是针对元素有效

     

    》Map集合的功能概述:                                                         

    1:添加功能                                                                  
            V put(K key,V value):添加元素。这个其实还有另一个功能

                如果键是第一次存储,就直接存储元素,返回null                       
                如果键不是第一次存在,就用值把以前的值替换掉,返回以前的值         
    2:删除功能                                                                  
            void clear():移除所有的键值对元素                                      
            V remove(Object key):根据键删除键值对元素,并把值返回                 
    3:判断功能                                                                  
            boolean containsKey(Object key):判断集合是否包含指定的键              
            boolean containsValue(Object value):判断集合是否包含指定的值           
            boolean isEmpty():判断集合是否为空                                    
    4:获取功能                                                                  
            Set<Map.Entry<K,V>> entrySet():得到键值对的集合                                
            V get(Object key):根据键获取值                                         
            Set<K> keySet():获取集合中所有键的集合                                 
            Collection<V> values():获取集合中所有值的集合                          
    5:长度功能                                                                 
            int size():返回集合中的键值对的对数                                   
                                                                                

    》Map的遍历方式

    Map<key类型,value类型> map=new HashMap<key类型,value类型>();

    >1.键到值   

    Set<key的类型>  set=map.keySet();//得到所有key的集合
    
           for(key的类型  key: set){
    
                  value类型  value=map.get(key);
    
                  System.out.println(key+"—"+value);
    
           }
    >2.键和值一起

    Set<Map.Entry<key类型,value类型>> set=map.entrySet();
    
        for(Map.Entry<key类型,value类型> entry: set){
    
               key类型=entry.getKey();
    
               value类型=entry.getValue();
    
               System.out.println(key+"—"+value);
    
        }

    import java.util.HashMap;
    import java.util.Map;
    
    public class MapDemo {
        public static void main(String[] args) {
            // 创建集合对象
            Map<String, String> map = new HashMap<String, String>();
    
            // 添加元素
            // V put(K key,V value):添加元素。这个其实还有另一个功能?先不告诉你,等会讲
            // System.out.println("put:" + map.put("文章", "马伊俐"));
            // System.out.println("put:" + map.put("文章", "姚笛"));
    
            map.put("邓超", "孙俪");
            map.put("黄晓明", "杨颖");
            map.put("周杰伦", "蔡依林");
            map.put("刘恺威", "杨幂");
    
            // void clear():移除所有的键值对元素
            // map.clear();
    
            // V remove(Object key):根据键删除键值对元素,并把值返回
            // System.out.println("remove:" + map.remove("黄晓明"));
            // System.out.println("remove:" + map.remove("黄晓波"));
    
            // boolean containsKey(Object key):判断集合是否包含指定的键
            // System.out.println("containsKey:" + map.containsKey("黄晓明"));
            // System.out.println("containsKey:" + map.containsKey("黄晓波"));
    
            // boolean isEmpty():判断集合是否为空
            // System.out.println("isEmpty:"+map.isEmpty());
            
            //int size():返回集合中的键值对的对数
            System.out.println("size:"+map.size());
    
            // 输出集合名称
            System.out.println("map:" + map);
        }
    }

  • 相关阅读:
    [题解]Magic Line-计算几何(2019牛客多校第三场H题)
    [题解]Crazy Binary String-前缀和(2019牛客多校第三场B题)
    [数论]快速幂取模
    [模板]大整数乘法——累加型
    [动态规划] 最大子段和问题
    2073
    17-2-24-D
    17-1-31-C
    2032
    1992
  • 原文地址:https://www.cnblogs.com/qq-757617012/p/4289612.html
Copyright © 2011-2022 走看看