集合已修改;可能无法执行枚举操作; 索引超出范围;未将对象引用设置到对象的实例

本文探讨了C#中处理集合时常见的错误,包括在foreach循环中删除元素导致的“集合已修改”异常,以及使用索引删除元素时可能出现的索引越界问题。此外,还讨论了LINQ查询时未检查null引用可能导致的问题,并提供了相应的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【1】集合已修改;可能无法执行枚举操作

foreach (var city in list)
            {
                if (city.CITYCODE.Contains("410706"))
                {
                    list.Remove(city);
                }
            }

foreach语句是对枚举数的包装,它只允许从集合中读取,不允许写入集合。

也就是,不能在foreach里遍历的时侯把它的元素进行删除或增加的操作的

[C#]集合已修改;可能无法执行枚举操作

 

【2】其他信息: 索引超出范围。必须为非负值并小于集合大小。

for (var i=0;i<118;i++)
            {
                if (list[i].CITYCODE.Contains("410706"))//,410705,410522
                {
                    list.RemoveAt(i);
                }
            }

            for (var i=0;i< list.Count(); i++)
            {
                if (list[i].CITYCODE.Contains("410706,410705,410522"))//
                {
                    list.RemoveAt(i);
                }
            }

    【3】其他信息: 未将对象引用设置到对象的实例。

            var result = from a in list
                             join c in airQuality on a.CITYCODE equals c.CITYCODE 
                             //orderby a.AQI ascending, a.CITYCODE ascending
                             into joinEmpDept
                             from da in joinEmpDept.DefaultIfEmpty()
                             select new
                             {
                                 da.PM10,
                                 da.PM25,
                                 da.CO,
                                 da.NO2,
                                 da.SO2,
                                 da.O3,
                                 da.AQI,
                                 da.AIRLEVEL,
                                 a.CITY
                             };

没有做null值的判断

                var result = from a in list
                             join c in airQuality on a.CITYCODE equals c.CITYCODE 
                             //orderby a.AQI ascending, a.CITYCODE ascending
                             into joinEmpDept
                             from da in joinEmpDept.DefaultIfEmpty()
                             select new
                             {
                                 PM10=da==null? -999 :da.PM10,
                                 PM25= da == null ? -999 : da.PM25,
                                 CO= da == null ? -999 : da.CO,
                                 NO2= da == null ? -999 : da.NO2,
                                 SO2= da == null ? -999 : da.SO2,
                                 O3= da == null ? -999 : da.O3,
                                 AQI= da == null ? -999 : da.AQI,
                                 AIRLEVEL=da.AIRLEVEL,
                                 a.CITY
                             };

 

没有解决

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值