Map

 

Map接口用于存储元素对(键和值)

Map接口中的方法:

    equals(Object o)   //比较对象是否相等

    hashCode    //

    clear()                      //清空map

    remove(Object key)  //删除key键对应的键值对

    put(Object key,Object value) //加入key-value对

    putAll(Map t)  

 

    entrySet()  //返回 Map 中所包含映射的 Set 视图。

                       //Set 中的每个元素都是一个 Map.Entry 对象,可以使用        

                       // getKey() 和 getValue() 方法(还有一个 setValue() 方法)访问后者的键元素和值元素

    keySet()     //返回 Map 中所包含键的 Set 视图。 删除 Set 中的元素还将删除 Map 中相应的映射(键和值)

    values()      //返回 map 中所包含值的 Collection 视图。 删除 Collection 中的元素还将删除 Map 中相应的映射(键和值)

    get(Object key)                  //返回与指定键(key)关联的值

    containsKey(Object key)     //判断是否包含key ,返回true or false;

    containsValue(Object value) //判断是否包含value ,返回true or false;

    isEmpty()   //判断map是否为空,返回true or false;

    size()   //判断map的大小,返回int

1. HashMap

HashMap提供所有可选的映射操作,并允许使用 null 值和 null 键,除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同

注意,此实现不是同步的。如果多个线程同时访问一个哈希映射,而其中至少一个线程从结构上修改了该映射,则它必须 保持外部同步。这一

般通过对自然封装该映射的对象进行同步操作来完成。如果不存在这样的对象,则应该使用 Collections.synchronizedMap 方法来“包装”该映射。最好在创建时完成这一操作,以防止对映射进行意外的非同步访问,如下所示:

Map m = Collections.synchronizedMap(new HashMap(...));

A: 遍历HashTable, 使用entrySet接口

    Java代码

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

map.put("1", 1);   

map.put("2", 2);   

map.put("3", 3);   

map.put("3", 3);   

     

Iterator itor=map.entrySet().iterator();   

while(itor.hasNext()){   

  Map.Entry<String,Integer> entry=(Map.Entry<String,Integer>)itor.next();   

  System.out.println("key="+entry.getKey().toString());   

  System.out.println("values="+entry.getValue().toString());   

}   

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

       map.put("1", 1);

       map.put("2", 2);

       map.put("3", 3);

       map.put("3", 3);

         

       Iterator itor=map.entrySet().iterator();

       while(itor.hasNext()){

         Map.Entry<String,Integer> entry=(Map.Entry<String,Integer>)itor.next();

         System.out.println("key="+entry.getKey().toString());

         System.out.println("values="+entry.getValue().toString());

       }

   

B: 遍历HashTable, 使用keySet 和 values接口

       Java代码

Set<String> keys=map.keySet();   

Iterator itor=keys.iterator();   

while(itor.hasNext()){   

    Object key=itor.next();   

    System.out.println("key="+key.toString());   

    System.out.println("value="+map.get(key).toString());   

}   

  

Collection co=map.values();   

Iterator itor=co.iterator();   

while(itor.hasNext()){   

    System.out.println("value="+itor.next());   

}   

       Set<String> keys=map.keySet();

       Iterator itor=keys.iterator();

       while(itor.hasNext()){

                Object key=itor.next();

                System.out.println("key="+key.toString());

                System.out.println("value="+map.get(key).toString());

        }

       Collection co=map.values();

       Iterator itor=co.iterator();

       while(itor.hasNext()){

                System.out.println("value="+itor.next());

        }

      

Hashtable和HashMap的区别:

1.Hashtable是Dictionary的子类,HashMap是Map接口的一个实现类;

2.Hashtable中的方法是同步的,而HashMap中的方法在缺省情况下是非同步的。即是说,在多线程应用程序中,不用专门的操作就安全地可以

使用Hashtable了;而对于HashMap,则需要额外的同步机制。但HashMap的同步问题可通过Collections的一个静态方法得到解决:

Map Collections.synchronizedMap(Map m)

这个方法返回一个同步的Map,这个Map封装了底层的HashMap的所有方法,使得底层的HashMap即使是在多线程的环境中也是安全的。

3.在HashMap中,null可以作为键,这样的键只有一个;可以有一个或多个键所对应的值为null。当get()方法返回null值时,即可以表示

HashMap中没有该键,也可以表示该键所对应的值为null。因此,在HashMap中不能由get()方法来判断HashMap中是否存在某个键,而应该用

containsKey()方法来判断

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值