- Collection中的集合,元素是孤立存在的(理解为单身),向集合中存储元素采用一个个元素的方式存储。
- Map中的集合,元素是成对存在的(理解为夫妻)。每个元素由键与值两部分组成,通过键可以找对所对应的值。
- Collection中的集合称为单列集合,Map中的集合称为双列集合。
- 需要注意的是,Map中的集合不能包含重复的键,值可以重复;每个键只能对应一个值。
- Map中常用的集合为HashMap集合、LinkedHashMap集合。
public static void main(String[] args) { Map<Integer,String> map = new HashMap<Integer, String>(); map.put(1,"aa"); map.put(2,"bb"); map.put(3,"cc"); //value //1.调用Map中values Collection<String> values = map.values(); //2.遍历集合 Iterator<String> i = values.iterator(); while(i.hasNext()) { System.out.println(i.next()); } //1.调用Map集合entrySet() Set<Map.Entry<Integer, String>> entrySet = map.entrySet(); //2.遍历entrySet,获取Map的映射关系 for( Map.Entry<Integer, String> entry :entrySet) { //3.通过entry对应关系,获取key,value Integer key = entry.getKey(); String value = entry.getValue(); System.out.println(key + " = " + value); } //keySet: //1.调用Map的Set keySet() Set<Integer> keys = map.keySet(); //2.遍历set集合,取出key值 for( Integer key :keys) { System.out.println(key); //3.通过key值,去map集合中获取value String s = map.get(key); System.out.println(s); } Iterator<Integer> it = keys.iterator(); while(it.hasNext()) { Integer key = it.next(); String s = map.get(key); System.out.println(s); } }
- HashMap<K,V>:存储数据采用的哈希表结构,元素的存取顺序不能保证一致。由于要保证键的唯一、不重复,需要重写键的hashCode()方法、equals()方法。
- LinkedHashMap<K,V>:HashMap下有个子类LinkedHashMap,存储数据采用的哈希表结构+链表结构。通过链表结构可以保证元素的存取顺序一致;通过哈希表结构可以保证的键的唯一、不重复,需要重写键的hashCode()方法、equals()方法。
- 注意:Map接口中的集合都有两个泛型变量<K,V>,在使用时,要为两个泛型变量赋予数据类型。两个泛型变量<K,V>的数据类型可以相同,也可以不同。
Map接口
最新推荐文章于 2021-02-27 15:14:49 发布