首先,数组和集合的区别:
Connection
Connection
List
和Set
,既没有继承也没有实现Connection
三者各自适用什么样的场景?
ArrayList
适合快速查找,LinkedList
适合增删元素Set
有:HashSet
、LinkedHashSet
和 TreeSet
。其中,TreeSet
中的元素可以使用Comparator
或者 Comparable
进行排序;LinkedHashSet
也按照元素的插入顺序对它们进行存储Map
有:HashMap
、LinkedHashSet
和TreeMap
。其中HashMap
是无序的,LinkedHashSet
有序,TreeMap
可通过Comparator
或者 Comparable
进行排序
另外HashTable
也可以实现键值对,并且相对于HashMap
是线程安全的,但是由于JAVA5以上 ConcurrentHashMap
是线程安全的,但现在已经基本被HashMap
取代怎么让HashMap同步?
Map m = Collections.synchronizeMap(hashMap);
ConcurrentHashMap
是HashTable
的替代 (即线程安全的)首先map<String,Object>是定义了一个Map集合变量,然后list<map<String,Object>>是定义了一个List的集合变量,是map的一个集合;map是那个list的其中一个值。 List<Map<String,Object> list=new ArrayList<Map<String,Object>>; Map<String,Object> map=new HashMap<String,Object>; list.add(map);//map是list中的其中一个值。
List集合中的对象是一个Map对象,而这个Map对象的键是String类型,值是Object类型
package com.test;
import java.util.*;
public class MyTest01 {
public static void main(String[] args) {
List<Map<String, Object>> listMaps = new ArrayList<Map<String, Object>>();
Map<String, Object> map1 = new HashMap<String, Object>();
map1.put("1", "a");
map1.put("2", "b");
map1.put("3", "c");
listMaps.add(map1);
Map<String, Object> map2 = new HashMap<String, Object>();
map2.put("11", "aa");
map2.put("22", "bb");
map2.put("33", "cc");
listMaps.add(map2);
for (Map<String, Object> map : listMaps) {
for (String s : map.keySet()) {
System.out.print(map.get(s) + " ");
}
}
System.out.println();
System.out.println("========================");
for (int i = 0; i < listMaps.size(); i++) {
Map<String, Object> map = listMaps.get(i);
Iterator iterator = map.keySet().iterator();
while (iterator.hasNext()) {
String string = (String) iterator.next();
System.out.println(map.get(string));
}
}
System.out.println("++++++++++++++++++++++++++++");
for (Map<String, Object> map : listMaps) {
for (Map.Entry<String, Object> m : map.entrySet()) {
System.out.print(m.getKey() + " ");
System.out.println(m.getValue());
}
}
System.out.println("-----------------------------");
}
}
一、提出问题 代码一:
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class Test {
public static void main(String args[]) {
List<Map<String, Object>> list = new ArrayList<Map<String,Object>>();
Map<String, Object> map = new HashMap<String, Object>();
for(int i=0;i<5;i++) {
// Map<String, Object> map = new HashMap<String, Object>();
map.put("a", i);
map.put("b", i);
list.add(map);
}
System.out.println(list);
}
}
代码二:
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class Test {
public static void main(String args[]) {
List<Map<String, Object>> list = new ArrayList<Map<String,Object>>();
// Map<String, Object> map = new HashMap<String, Object>();
for(int i=0;i<5;i++) {
Map<String, Object> map = new HashMap<String, Object>();
map.put("a", i);
map.put("b", i);
list.add(map);
}
System.out.println(list);
}
}
二、给出答案 猜猜看代码一二运行的结果分别是啥?
没错,就是:
代码一:
[{a=4,b=4},{a=4,b=4},{a=4,b=4},{a=4,b=4},{a=4,b=4}] 代码二:
[{a=0,b=0},{a=1,b=1},{a=2,b=2},{a=3,b=3},{a=4,b=4}]
三、问题分析 代码一中,List<Map<String, Object>>里面存放的是map对象的地址,尽管循环了五次,但是每次的map对象对应的都是同一个地址,即listMap里面存放的是五个同样的map对象。 代码二中,每次循环的时候都实例化一个新的map对象,这样list在执行add方法的时候,每次都是存的不一样的map对象。 可以通过debug来观察list存放的map对象对应的id。如图:
代码一:
代码二:
四、总结 通过上面的分析,我们可以知道,以后需要创建不同的map对象的时候,需要在循环里面进行map的创建。
而不是在循环体外面,因为List<Map<String, Object>>指向的是map对象的地址。