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>的数据类型可以相同,也可以不同。