A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© liuxiaoye 中级黑马   /  2016-2-18 21:38  /  422 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

HashTable:底层是哈希表数据结构,不可以存入null键null值,该集合线程是同步的
HashMap:底层是哈希表数据结构,可以存入null键null值,该集合线程是不同步的HashTable和HashMap除了上述不同,其他都一样
该例子演示HashMap存入一个null键来获取值和存入一个null值来获取它public class HashMapTest {  
    public static void main(String[] args) {  





        Map<String, String> map = new HashMap<String, String>();  
        map.put(null, "ss");
        System.out.println(map.get(null));  
        map.put("a", null);  
        System.out.println(map.get("a"));  
    }  
}  
HashMap如果存入一个相同的键但是不同的值的时候它会将旧的值返回
public class HashMapTest {  
    public static void main(String[] args) {  
        Map<String, String> map = new HashMap<String, String>();  
        map.put("a", "ss");  
      System.out.println(map.put("a", "bb"));  
    }  
}  
结果:ss
第一种HashMap集合的遍历
public class HashMapTest {  
    public static void main(String[] args) {  
        Map<String, String> map = new HashMap<String, String>();  
        map.put("a1", "ss-1");  
        map.put("a2", "ss-2");  
        map.put("a3", "ss-3");  
        map.put("a4", "ss-4");  
        map.put("a5", "ss-5");  
        Set<String> set = map.keySet();//获取所有的key值  
        Iterator<String> it = set.iterator();  
        while(it.hasNext()){  
            String k = it.next();  
            String v = map.get(k);              
            System.out.println("k:"+k+",value:"+v);  
        }
    }  
}  
结果:k:a1,value:ss-1
k:a2,value:ss-2
k:a3,value:ss-3
k:a4,value:ss-4
k:a5,value:ss-5

第二种HashMap集合的遍历

[java] view plain copy

public class HashMapTest {  



    public static void main(String[] args) {  





        Map<String, String> map = new HashMap<String, String>();  



        map.put("a1", "ss-1");  

        map.put("a2", "ss-2");  

        map.put("a3", "ss-3");  

        map.put("a4", "ss-4");  

        map.put("a5", "ss-5");  





        Set<Map.Entry<String, String>> set = map.entrySet();  



        Iterator<Map.Entry<String, String>> it = set.iterator();  



        while(it.hasNext()){  



            Map.Entry<String, String> me = it.next();  

            String k = me.getKey();  

            String v = me.getValue();  



            System.out.println("k:"+k+",value:"+v);  



        }  







    }  



}  

Map.Entry是一个接口,用来存Map的键值关系,用HashMap的entrySet方法返回一个Map.Entry实例(因为HashMap里面有一个静态的Entry内部类),然后根据getKey和getValue获取对应的键值



TreeMap:底层是二叉树结构,线程不同步,可以给键进行排序


0 个回复

您需要登录后才可以回帖 登录 | 加入黑马