加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

Java中map接口 遍历map

发布时间:2020-12-15 07:53:13 所属栏目:Java 来源:网络整理
导读:转自:https://www.cnblogs.com/wjk921/p/4918442.html java集合框架用于存储数据,也被称为集合类 位于java.util包下 java.util包下常用接口和类 Collection和Map是Java集合框架的根接口 List集合是有序集合,集合中的元素可以重复,访问集合中的元素可以根

转自:https://www.cnblogs.com/wjk921/p/4918442.html

java集合框架用于存储数据,也被称为集合类

位于java.util包下

java.util包下常用接口和类

Collection和Map是Java集合框架的根接口

List集合是有序集合,集合中的元素可以重复,访问集合中的元素可以根据元素的索引来访问。

Set集合是无序集合,集合中的元素不可以重复,访问集合中的元素只能根据元素本身来访问(也是不能集合里元素不允许重复的原因)。

Map集合中保存Key-value对形式的元素,访问时只能根据每项元素的key来访问其value。

Map接口

Map接口不是Collection接口的继承。Map接口用于维护键/值对(key/value pairs)。该接口描述了从不重复的键到值的映射。

HashMap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度。

HashMap最多只允许一条记录的键为Null;允许多条记录的值为Null;HashMap不支持线程的同步,即任一时刻可以有多个线程同时写HashMap;

可能会导致数据的不一致。如果需要同步,可以用Collections的synchronizedMap方法使HashMap具有同步的能力。

TreeMap 不仅可以保持顺序,而且可以用于排序

Map与Collection:
?? Map与Collection在集合框架中属并列存在
?? Map存储的是键值对
?? Map存储元素使用put方法,Collection使用add方法
?? Map集合没有直接取出元素的方法,而是先转成Set集合,在通过迭代获取元素
?? Map集合中键要保证唯一性

常用方法:

?

添加:put(K key,V value)? 将指定的值与此映射中的指定键关联
??????? putAll(Map<? extends K,? extends V> m)??从指定映射中将所有映射关系复制到此映射中
? ?

import java.util.HashMap;  
import java.util.Map;  
  
/** 
 *  
 * Map集合添加
 * 
 */  
public class MapDemo   
{  
    public static void main(String[] args)  
    {  
        Map<String,Integer> m = new HashMap<String,Integer>();  
          
        m.put("zhangsan",19);  
        m.put("lisi",49);  
        m.put("wangwu",20);
        m.put("hanmeimei",null);  
          
        System.out.println(m);  
    }  
}  

?

删除:clear()? 从此映射中移除所有映射关系?

? ? ? ? remove(Object key) 如果存在一个键的映射关系,则将其从此映射中移除 ?

import java.util.HashMap;  
import java.util.Map;  
  
/** 
 *  
 * Map集合删除
 * 
 */  
public class MapDemo   
{  
    public static void main(String[] args)  
    {  
        Map<String,49);
        m.put("wangwu",20);  
        m.put("hanmeimei",null);         
        System.out.println(m);  
          
        System.out.println(m.remove("wangwu"));  
          
        m.clear();  
        System.out.println(m);        
    }  
}  

?


判断:containsValue(Object value)? 如果此映射将一个或多个键映射到指定值,则返回?true

??????? containsKey(Object key)???如果此映射包含指定键的映射关系,则返回?true

????????isEmpty()? 如果此映射未包含键-值映射关系,则返回?true

import java.util.HashMap;  
import java.util.Map;  
  
/** 
 *  
 * Map集合判断
 * 
 */  
public class MapDemo   
{  
    public static void main(String[] args)  
    {  
        Map<String,20); 
        m.put("hanmeimei",null);         
        System.out.println(m);  
          
        System.out.println(m.containsKey("lisi"));  
        System.out.println(m.containsValue(20));  
        System.out.println(m.isEmpty());          
    }  
}  

?


?获取:get(Object key) ?返回指定键所映射的值;如果此映射不包含该键的映射关系,则返回?null

? ? ? ? size()? 返回此映射中的键-值映射关系数。

? ? ? ? values()? 返回此映射中包含的值的 collection 视图?

? ? ????entrySet()? 返回此映射中包含的映射关系的 set 视图。
? ? ? ? keySet()? 返回此映射中包含的映射关系的 key 视图。

?

import java.util.HashMap;  
import java.util.Map;  
  
/** 
 *  
 * Map集合获取
 * 
 */  
public class MapDemo   
{  
    public static void main(String[] args)  
    {  
        Map<String,null);         
        System.out.println(m);  
          
        System.out.println(m.get("lisi"));  
        System.out.println(m.size());
        System.out.println(m.values()); 
        System.out.println(m.entrySet());
        zhangsan=19,hanmeimei=null]  
        System.out.println(m.keySet());
    }  
}  

?

?

map集合的两种取出方式:?
1 . Set<k> keySet:将map中所有的键存入到Set集合。因为set具备迭代器。所有可以迭代方式取出所有的键,在根据get方法。获取每一个键对应的值。?
???? Map集合的取出原理:将map集合转成set集合。在通过迭代器取出。?
2 . Set<Map.Entry<k,v>> entrySet:将map集合中的映射关系存入到了set集合中,而这个关系的数据类型就是:Map.Entry?
?? ? Entry其实就是Map中的一个static内部接口。?
??? ?定义在内部因为只有有了Map集合,有了键值对,才会有键值的映射关系。关系属于Map集合中的一个内部事物。而且该事物在直接访问Map集合中的元素。

map遍历的几种方案:

1.用for循环

for(Map.Entry<String,String> entry:map.entrySet()){
          System.out.println(entry.getKey()+"--->"+entry.getValue());
 }

2.用迭代?

Set set = map.entrySet();     
Iterator i = set.iterator();     
while(i.hasNext()){  
    Map.Entry<String,String> entry1=(Map.Entry<String,String>)i.next();
    System.out.println(entry1.getKey()+"=="+entry1.getValue());
}

3.用keySet()迭代?

Iterator it=map.keySet().iterator();
while(it.hasNext()){
    String key;
    String value;
    key=it.next().toString();
    value=map.get(key);
    System.out.println(key+"--"+value);
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读