---> HashMap :底层基于哈希表
      存储原理也使用哈希表来存放的:
            往HashMap添加了元素 ,首先会调用键的hashCode方法 获得一个哈希值,然后经过运算获取一个位置。
            情况1:如果位置上没有元素 ,那么直接将该元素存放在此位置。
            情况2:如果位置上有了元素,那么还会调用元素equals方法与这个位置的元素做比较,如果反回回来的true,
            那么就被视为相同的键,就不存,如果返回回来时false,那么就可存该元素。
         
      ---> TreeMap : 给予二叉树的结构存储。 特点:以键来做自然排序
           使用注意点:
              1.往TreeMap 添加的元素时,如果元素的键具备自然排序功能,那么就会通过自然排序对元素进行排序。
              2.往TreeMap 添加的元素时 如果不具备自然排序特性 ,键所属的类必须要实现Comparable接口,把这个键的比较规则
              定义在compareTo方法中。
              3.往TreeMap 添加的元素时 如果不具备自然排序特性,也没有实现Comparable接口,创建TreeMap的时候给他一个比较器
              结构 :
                class 类名  implements Compartor 接口{
               
                }
               
                键的比较规则定义在compare方法中。
           
      ---> HashTable : HashMap 一样的使用,线程安全。  访问比较慢  (了解)

   --->Map集合的便利方式(三种)

   map遍历元素方式一: keySet(); Set视图  -->获取所有的键用Set集合来保存
        特点 : 通过遍历键 ,通过键来取值
        Set<String> set = map.keySet();  
        Iterator<String> it = set.iterator();
        while(it.hasNext()){
            
            String key = it.next();
            System.out.println("键"+key +":值"+map.get(key));
        }

  map集合遍历方式二: values(); 获取map集合中所有的值,用Collection集合来保存
        Collection<String> coll = map.values();
        创建一个迭代器
        Iterator<String> it = coll.iterator();
        while(it.hasNext()){
            
            System.out.println("值:"+it.next());
            
        }

  map集合的遍历方式三:entrySet();
        Set<Map.Entry<String, String>> entrys = map.entrySet();
        获取迭代器
        Iterator<Map.Entry<String, String>> it = entrys.iterator();
        
       
         Map.Entry : 接口  :提供给用户来操作map集合
           getKey(); 获取键
           getValue();获取值
           setValue();更改值
        
        
        while(it.hasNext()){
            
            Map.Entry<String, String> entry = it.next();
      
            String key = entry.getKey();
            if(("1").equals(key)){
                
                entry.setValue("哈哈");
            }
            
            System.out.println("键:"+entry.getKey() + " 值:"+entry.getValue());
        }

Map集合的应用及其遍历方式的更多相关文章

  1. Map集合的两种遍历方式

    Map集合:即 接口Map<K,V> map集合的两种取出方式:    1.Set<k> keyset: 将map中所有的键存入到set集合(即将所有的key值存入到set中) ...

  2. Map集合的几种遍历方式

    Map<String ,String> map=new HashMap<String,String>(); map.put("1","value1 ...

  3. Map集合的四种遍历方式

    很久以前写的代码,和上一个做比较吧!便于以后查看 import java.util.HashMap; import java.util.Iterator; import java.util.Map; ...

  4. Map集合的四种遍历方式(转载)

    import java.util.HashMap; import java.util.Iterator; import java.util.Map; public class TestMap { pu ...

  5. Map集合的4种遍历方式

    import java.util.HashMap;import java.util.Iterator;import java.util.Map; public class TestMap {    p ...

  6. Map集合的两种取出方式

    Map集合有两种取出方式, 1.keySet:将Map中的键存入Set集合,利用set的迭代器来处理所有的键 举例代码如下: import java.util.*; class Test { publ ...

  7. Java中List集合的三种遍历方式(全网最详)

    List集合在Java日常开发中是必不可少的,只要懂得运用各种各样的方法就可以大大提高我们开发的效率,适当活用各种方法才会使我们开发事半功倍. 我总结了三种List集合的遍历方式,下面一一来介绍. 首 ...

  8. Map集合的四种遍历

    Map集合遍历 Map<String,Integer> m = new HashMap<String,Integer>(); m.put("one",100 ...

  9. Map<String,String>集合的四种遍历方式 其中有一种针对大容量的数据集合

随机推荐

  1. 成为 Linux 终端高手的七种武器 之七 条件执行&&

    7.条件执行 Bash 也可以连续执行两条命令。 第二条命令仅在第一条命令成功执行后才会开始执行。如要如此,你可以通过键入“&&”,也就是两个“&”字符进行分隔,在同一行输入两 ...

  2. SQLServer中比较末尾带有空格的字符串遇到的坑

    最近发现SQLServer中比较字符串的时候 如果字符串末尾是空格 那么SQLServer会无视那些空格直接进行比较 这和程序中平时的字符串判断逻辑不统一 );set @a=N'happycat198 ...

  3. Android ViewPager初探:让页面滑动起来

    下一篇:<Android ViewPager再探:增加滑动指示条> ViewPager需要用到适配器PagerAAdapter,以下四个函数需要重写: instantiateItem(Vi ...

  4. 连接到Windows Azure Point to Site VPN

    Windows Azure支持两种模式的VPN接入: Site to Site,接入端需要有固定的公网IP地址,用于连接局域网和Windows Azure的虚拟网络. Point to Site,客户 ...

  5. HDU 2117 取(2堆)石子游戏【wzf博弈】

    题意:威佐夫博弈原型,除了输出先手能不能胜,还要输出先手的第一手选择. 思路:预处理出1000000以内的所有奇异局势.对于每个自然数,其必然是某一个奇异局势的a或者b.故对于一个非奇异局势,必定有一 ...

  6. 网络之OSI&&TCP/IP比较

    共同点: 1.OSI和TCP/IP都采用了层次结构的概念 2.都能够提供面向链接(TCP)和无链接(UDP)两种通信服务机制 不同点: 1.前者7层,后者两层 2.对可靠性要求不同,TCP/IP要求高 ...

  7. Unity减少GC Alloc之 使用for替换foreach

    Unity中foreach会增加GC unity中for效率比foreach高? 在unity中使用foreach遍历集合会增加gc alloc,参考的话题:作为Unity3D的脚本而言,c#中for ...

  8. Android驱动入门-LED--HAL硬件抽象层程序设计①

    硬件平台: FriendlyARM Tiny4412 Cortex-A9 操作系统: UBUNTU 14.04 LTS 时间:2016-09-21  16:15:26 设计HAL硬件抽象层程序,则需要 ...

  9. [No000018]都在背单词,为啥学霸那么厉害-如何在一天内记200个单词?

  10. 转:Git 求生手册 - 第三章分支工作

    from:http://newbranch.cn/zhi-zuo-fen-zhi-lai-gong-zuo-git-gh-pages-branching/ 来自:片段 实战 说了这么一大堆分支的东西. ...