项目背景:
当向数据库中插入企业信息时,如果企业库中有该信息,则不进行插入;如果企业表中没有该企业信息,则进行插入操作;
做法:
需要将企业库中已有的企业id查询出来,与要插入的一批企业信息做一下过滤操作;
坑:
list<CompanyInfo> list; //这是要插入的所有的企业信息
List<String> companyCodes; //这是企业表中有的企业编码
//我们要根据companyCodes对list做一下过滤操作
//错误做法,随着list的变小,for循环的次数也会变小;
for(CompanyInfo com : list){
if(companyCodes.contains(com.getCompanyCode)){
list.remove(com);
}
}
//错误做法2 这是一旦发生移除元素的操作,就是越界报错
int size = list.size();
for(int i=0;i<size;i++){
if(companyCodes.contains(list.get(i).getCompanyCode){
list.remove(list.get(i));
}
}
//错误做法3,也会报错,这是因为list=list2,都是指向的一个引用对象,一个减小,另外一个也减小
List<CompanyInfo> list2 = list;
for(CompanyInfo com : list){
if(companyCodes.contains(com.getCompanyCode)){
list2.remove(com);
}
}
//正确做法:
list<CompanyInfo> res = new ArrayList<>();
for(CompanyInfo com : list){
res.add(com);
}
//此时再进行移除过滤操作即可。
for(CompanyInfo com : list){
if(companyCodes.contains(com.getCompanyCode)){
res.remove(com);
}
}
这是因为随着list的remove操作,它的大小会改变的,for循环的次数会动态改变的;