代码一:
for (int i = 0; i < modelList.Count; i++)
{
ThirteenCalcInsuranceModel escCompanyData = haveThirteenData.FirstOrDefault(t => t.EmployeeNo == modelList[i].EmployeeNo && t.SalaryComoanyID != modelList[i].SalaryComoanyID);
if (escCompanyData != null)
{
modelList.Remove(modelList[i]);
LogUtil.InfoLog.Info("员工号为" + modelList[i].EmployeeNo + "的员工,十三薪数据已存在且自动忽略!");
}
}
代码二:
foreach (var item in modelList)
{
LogUtil.InfoLog.Info("多发新账套员工EmployeeNo = " + item.EmployeeNo);
// 去除十三薪数据已经导入的员工
ThirteenCalcInsuranceModel escCompanyData = haveThirteenData.FirstOrDefault(t => t.EmployeeNo == item.EmployeeNo && t.SalaryComoanyID != item.SalaryComoanyID);
if (escCompanyData != null)
{
modelList.Remove(item);
LogUtil.InfoLog.Info("员工号为" + escCompanyData.ESID + "的员工,十三薪数据已存在!");
}
}
两段代码都是循环遍历modelList,原则上是没有什么问题的,但是在运行的时候,第二段代码出现的报错,“集合已修改,可能无法执行枚举操作”,这就出现问题了。
问题的原因在于,在循环遍历list时,执行了remove删除操作,这样就会报错:查询集合已修改,可能无法执行枚举操作查一下,这个师使用foreach时出现的典型问题。
由此深入了解了下for循环和foreach循环的使用注意事项: