最近比较频繁的用HashMap,在此记下笔记,以备下次使用
1、遍历
Iterator it = map.entrySet().iterator();
while (it.hasNext()) {
Map.Entry entry = (Map.Entry) it.next();
entry.getValue();
entry.getKey();
}
2、containsKey(),
containsValue()
很有用,不用遍历map去找 包含该key/value就返回true
3、相同的key再put一次就会更新其value
Map map=new HashMap();
BigDecimal a=new BigDecimal(100);
map.put("aa",a);
BigDecimal aa=(BigDecimal)map.get("aa");
aa=aa.add(new BigDecimal(100));
map.put("aa",aa);
System.out.println(map);
map.get("aa"):200
例外1:单例模式
Calendar calendar=Calendar.getInstance();
map.put("dd",calendar);
Calendar cal=(Calendar)map.get("dd");
cal.add(Calendar.YEAR,2);
System.out.println(map);
此时不用再put一次,年会加2
例外2:map放的是集合
Map map=new HashMap();
ArrayList a=new ArrayList();
a.add("a1");
a.add("a2");
map.put("a",a);
System.out.println(map);
ArrayList b=(ArrayList)map.get("a");
b.add("a3");
System.out.println(map);
{a=[a1, a2, a3]}