第一种使用遍历的方式
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直接处理
public static <T> List<T> removeNull(List<? extends T> oldList) {
//使用API方式,使用的是迭代器其本质上还是循环
oldList.removeAll(Collections.singleton(null));
return (List<T>) oldList;
}
两者比较:
相同较大数据量,第一种方法要比第二种稍微快一点,但优势并不明显,上万条数据几十毫秒的差别,很明显,
第二种处理只用了一行代码就搞定,推荐使用第二种方式处理