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元素唯一性,可以快速对一个集合进行去重。

博客介绍了集合操作的高效方法与注意事项。判断集合元素是否为空用isEmpty()方法;不在foreach循环里进行元素的remove/add操作,remove元素用lterator方式;使用entrySet遍历Map类集合KV;注意Map类集合K/V能否存null值;还可利用set元素唯一性对集合去重。
202

被折叠的 条评论
为什么被折叠?



