我自己去实验了。事实证明,使用 1000 个元素创建HashMap 的 ArrayList 的方法大约快 40 倍。
public class HashMapVsArrayOfHashMap {
public static void main(String[] args){
ArrayList<HashMap<String, String>> listOfMaps=new ArrayList<HashMap<String,String>>();
for( int i=0;i<1000;i++){
final int finalI=i;
listOfMaps.add(new HashMap<String, String>(){{put("asdfasdfasdfasdfadsf"+finalI,"asdfsdafasdfsadfasdf"+finalI);}});
}
LinkedHashMap<String, String> map=new LinkedHashMap<String, String>();
for(int i=0;i<1000;i++)
map.put("asdfasdfasdfasdfadsf"+i,"asdfsdafasdfsadfasdf"+i);
int position=700;
testArrayList("Method1:ArrayListOfHashMaps",position,listOfMaps);
testHashMap("Method2:LinkedHashMap",position,map);
}
private static void testArrayList(String string, int position,
ArrayList<HashMap<String, String>> listOfMaps) {
long start, end;
start=System.nanoTime();
listOfMaps.get(position).get("asdfasdfasdfasdfadsf"+position);
end=System.nanoTime();
System.out.println(string+"|Difference = "+(end-start));
}
private static void testHashMap(String string, int position,
LinkedHashMap<String, String> map) {
long start, end;
start=System.nanoTime();
String s= new ArrayList<String>(map.keySet()).get(position);
end=System.nanoTime();
System.out.println(string+"|Difference = "+(end-start));
}
}
data:image/s3,"s3://crabby-images/8fa66/8fa6605850034461602072f2043df4e26a3079a1" alt="在此处输入图像描述"
data:image/s3,"s3://crabby-images/8a0ae/8a0aecd946b4a795e2551526797312b39bc34e5d" alt="在此处输入图像描述"
data:image/s3,"s3://crabby-images/1fe15/1fe1536576becc5c177b6726ad8c3bd6a4efa8ad" alt="在此处输入图像描述"
当您将大小增加到 30,000 个元素时 - 差异是巨大的。
data:image/s3,"s3://crabby-images/63a89/63a89c13c8aed6e8005909d1b90d5e3d88bde966" alt="在此处输入图像描述"
data:image/s3,"s3://crabby-images/59a1b/59a1bbac7e3a71c717505ed32f4a8bf289a9e704" alt="在此处输入图像描述"
data:image/s3,"s3://crabby-images/b6ec6/b6ec6e7300755bcdf07e5e32999b423d79c0b44e" alt="在此处输入图像描述"