1、判断所有集合内部的元素是否为空,使用isEmpty()方法,而不是size()==0的方式。
说明:前者的时间负责度为o(1),而且可读性更好。
lf(map.isEmpty()){}
2、不要在foreach循环里进行元素的remove/add操作。remove元素请使用lterator方式,如果并发操作,需要对lterator对象加锁。
正例:
list list.=new arraylist();
list.add(“1”);
iterator iterator=list.iterator();
while(iterator.hashNext()){
string item=iterator.next();
if(删除元素条件){
iterator.remove();
}
}
反例:
for(string item : list){
if(“1”.equals(item)){
list.remove(item);
}
}
如果把1改为2,反例中会报错
3、使用 entrySet 遍历 Map 类集合 KV,而不是 keySet 方式进行遍历。
说明:keySet 其实是遍历了 2 次,一次是转为 Iterator 对象,另一次是从 hashMap 中取出 key 所对应的
value。而 entrySet 只是遍历了一次就把 key 和 value 都放到了 entry 中,效率更高。如果是 JDK8,使用
Map.forEach 方法。
正例:values()返回的是 V 值集合,是一个 list 集合对象;keySet()返回的是 K 值集合,是一个 Set 集合对
象;entrySet()返回的是 K-V 值组合集合。
4、高度注意 Map 类集合 K/V 能不能存储 null 值的情况,如下表格:
5、利用set元素唯一性,可以快速对一个集合进行去重。