私たちは皆、反復順序の設定(そのような実装を除く)doesn't guarantee
を知っています。そのため、以下のサンプル コードでこれを確認しようとしました。
public static void main(String[] args) throws InterruptedException {
Map<String,String> lMap=new HashMap<String, String>();
lMap.put("A", "A");
lMap.put("B", "B");
lMap.put("C", "C");
lMap.put("D", "D");
lMap.put("E", "E");
lMap.put("F", "F");
lMap.put("G", "G");
lMap.put("H", "H");
lMap.put("I", "I");
lMap.put("J", "J");
lMap.put("K", "K");
lMap.put("L", "L");
for(int i=0;i<10000;i++){
Thread.sleep(100);
Set<Entry<String, String>> entrYset=lMap.entrySet();
for(Map.Entry<String, String> e:entrYset){
System.out.println(e.getKey()+" , "+e.getValue());
}
System.out.println("******************************************************");
}
}
上記のコードを何度も実行したところ、レコードが順番に印刷されていることがわかりました。
私の質問は、Java がHashMapが順序付けられていないと主張する場合、なぜこのレコードが順番に印刷されるのかということです。誰かが例を挙げて理由を教えてくれれば、それは素晴らしいことです。