概念:
现实生活中,我们常会看到这样的一种集合:IP地址与主机名,身份证号与个人,系统用户名与系统用户对象等,这种一一对应的关系,就叫做映射。Java提供了专门的集合类用来存放这种对象关系的对象,即java.util.Map接口,它是所有双列集合的父接口,用来储存键值对。 需要注意的是,Map中的集合不能包含重复的键,值可以重复;每个键只能对应一个值 。
Map接口的常用实现类:
- HashMap<K,V>:存储数据采用的哈希表结构,元素的存取顺序不能保证一致。由于要保证键的唯一、不重复,需要重写键的hashCode()方法、equals()方法。
- LinkedHashMap<K,V>:HashMap下有个子类LinkedHashMap,存储数据采用的哈希表结构+链表结构。通过链表结构可以保证元素的存取顺序一致;通过哈希表结构可以保证的键的唯一、不重复,需要重写键的hashCode()方法、equals()方法。
Map接口中定义了很多方法,常用的如下:
- public V put(key,value) : 把指定的键与指定的值添加到Map集合中。
- public V remove(key): 把指定的键 所对应的键值对元素 在Map集合中删除,返回被删除元素的值。
- public V get(key):根据指定的键,在Map集合中获取对应的值。
- boolean containskey(object key):判断集合中是否包含指定的键。
- public Set<K> keySet(): 获取Map集合中所有的键,存储到Set集合中。
- public Set<Map.Entry<k,v>> entrySet(): 获取到Map集合中所有的键值对对象的集合(Set集合)。
- public V getkey():获取Entry对象中的键。
- public V getvalue():获取Entry对象中的值。
使用put方法时,若指定的键(key)在集合中没有,则没有这个键对应的值,返回null,并把指定的键值添加到集合中;
若指定的键(key)在集合中存在,则返回值为集合中键对应的值(该值为替换前的值),并把指定键所对应的值,替换成指定的新值。
Map集合遍历
- Map集合遍历键值方式
public class MapDemo01 {public static void main(String[] args) {//创建Map集合对象 HashMap<String, String> map = new HashMap<String,String>();//添加元素到集合 map.put("胡歌", "霍建华");map.put("郭德纲", "于谦");map.put("薛之谦", "大张伟");//获取所有的键 获取键集Set<String> keys = map.keySet();// 遍历键集 得到 每一个键for (String key : keys) {//key 就是键//获取对应值String value = map.get(key);System.out.println(key+"的CP是:"+value);} }
}
- Map集合遍历键值对方式
public class MapDemo02 {public static void main(String[] args) {// 创建Map集合对象 HashMap<String, String> map = new HashMap<String,String>();// 添加元素到集合 map.put("胡歌", "霍建华");map.put("郭德纲", "于谦");map.put("薛之谦", "大张伟");// 获取 所有的 entry对象 entrySetSet<Entry<String,String>> entrySet = map.entrySet();// 遍历得到每一个entry对象for (Entry<String, String> entry : entrySet) {// 解析 String key = entry.getKey();String value = entry.getValue(); System.out.println(key+"的CP是:"+value);}}
}
tips:Map集合不能直接使用迭代器或者foreach进行遍历。但是转成Set之后就可以使用了。