方法一:使用 for 循环处理集合
- 思路:这种处理方式是把要处理的集合进行遍历,取出其中不为空的元素,添加到新的集合中,代码如下:
public static <T> List<T> removeNull(List<? extends T> oldList) {
// 临时集合
List<T> listTemp = new ArrayList();
for (int i = 0;i < oldList.size(); i++) {
// 保存不为空的元素
if (oldList.get(i) != null) {
listTemp.add(oldList.get(i));
}
}
return listTemp;
}
方法二:使用系统api
- 集合空元素的处理,api 有直接处理的方法,使用的是迭代器,本质上还是 for 循环的思想,代码:
// 演化:
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<String>();
list.add("name");
list.add("age");
list.add("from");
list.add("null");
List<String> list2 = new ArrayList<String>();
list2.add(null);
list.removeAll(list2);
}
//简化成一句话就是
countMap_List.removeAll(Collections.singleton(null));
- 对比,相同较大数据量,第一种方法要比第二种稍微快一点,但优势并不明显,上万条数据才几十毫秒的差别,很明显,第二种处理只用了一行代码就搞定,推荐使用第二种方式处理