Java学习笔记——Map接口

Map接口

Map接口

  • Map接口中键和值一一映射. 可以通过键来获取值。

  • 异常

    • NoSuchElementException:访问的值不存在
    • ClassCastException:对象类型错误
    • UnsupportedOperationException:尝试修改一个只读的Map
  • 常用方法

 

  • Entry是Map接口中提供的一个静态内部嵌套接口。简单来说Entry就是一个包含键和值的对象

     

     

    • getKey()方法:获取Entry对象中的键
    • getValue()方法:获取Entry对象中的值 
 1 public class MapDemo {
 2     public static void main(String[] args) {
 3         //创建Map对象
 4         Map<String, String> map = new HashMap<String,String>();
 5         //给map中添加元素
 6         map.put("邓超", "孙俪");
 7         map.put("李晨", "范冰冰");
 8 map.put("刘德华", "柳岩");
 9         //获取Map中的所有key与value的对应关系
10         Set<Map.Entry<String,String>> entrySet = map.entrySet();
11         //遍历Set集合
12         Iterator<Map.Entry<String,String>> it =entrySet.iterator();
13         while(it.hasNext()){
14             //得到每一对对应关系
15             Map.Entry<String,String> entry = it.next();
16             //通过每一对对应关系获取对应的key
17             String key = entry.getKey();
18             //通过每一对对应关系获取对应的value
19             String value = entry.getValue();
20             System.out.println(key+"="+value);
21         }
22     }
23 }

 

HashMap<K,V>类

  • 存储数据采用的哈希表结构,元素的存取顺序不能保证一致。
  • 由于要保证键的唯一、不重复,需要重写键的hashCode()方法、equals()方法。
  • 非线程安全
  • 可以存null键、null值

LinkedHashMap<K,V>类

  • HashMap下有个子类LinkedHashMap,存储数据采用的哈希表结构+链表结构。
  • 通过链表结构可以保证元素的存取顺序一致
  • 通过哈希表结构可以保证的键的唯一、不重复,需要重写键的hashCode()方法、equals()方法。

Hashtable类

  • 与HashMap类似,但Hashtable不可以存null键null值
  • 线程安全,较HashMao效率较低

注意

  • Map接口中的集合都有两个泛型变量<K,V>,在使用时,要为两个泛型变量赋予数据类型。两个泛型变量<K,V>的数据类型可以相同,也可以不同。
posted @ 2019-05-27 06:58  大梦谁觉  阅读(214)  评论(0编辑  收藏  举报