Привет, у меня есть следующий код, который производит странное поведение. Свойство экземпляра объектов, содержащихся в IEnumerable, произведенном LINQ к объектам, не обновляется в последующих операторах Foreach. Заявление FOREAFEACH должно эксплуатировать iEnumerable. Вместо этого раствор должен перечислять его раньше.
Хотя я нашел решение, которое я не видел этого документированного нигде в книгах, ни статьях, имеющих дело с подобными примерами. Возможно, кто-то с сложным знанием LINQ может объяснить это.
Это потребовалось в день, чтобы определить точную причину ошибки, и не легко отладить в большом приложении. Затем я воспроизводил его в гораздо более простых условиях, представленных ниже.
public class MyClass
{
public int val ;
}
public class MyClassExtrax
{
public MyClass v1 { get; set; }
public int prop1 { get; set; }
}
void Main()
{
List <MyClass> list1 = new List<MyClass>();
MyClass obj1 = new MyClass(); obj1.val = 10;
list1.Add(obj1);
MyClass obj2 = new MyClass();
obj2.val = 10;
list1.Add(obj2);
IEnumerable<MyClassExtrax> query1 =
from v in list1
where v.val >= 0
select new MyClassExtrax{ v1=v , prop1=0 } ;
//query1=query1.ToList(); solves the problem..but why is this needed..?
foreach (MyClassExtrax fj in query1)
{
fj.v1.val = 40;
fj.prop1 = 40; //property does not get updated..
}
foreach (MyClass obj in list1)
{
Console.WriteLine("in list 1 value is {0} : ", obj.val);
}
foreach (MyClassExtrax obj in query1)
{
Console.WriteLine("in MyClassExtra list v1.val is {0}, prop1 is {1} ", obj.v1.val, obj.prop1);
}
}
Выход: В списке 1 значение 40:
в списке 1 значение составляет 40:
в списке myclassextra v1.val 40, проп1 равен 0
в списке myclassextra v1.val 40, проп1 0
Как вы можете видеть PROP1, не обновляется до 40. !!