开发者

Efficient way of updating a collection from another collection

Is the following way of updating an ObservableCollection from another one (both based on the same class) good enough or it better to be done in another way (or just to be improved)?

foreach (MyEntity c in collection2)
    {
       collection1.Where(p => p.EntID == c.EntID).FirstOrDefault().Field1 = c.Field1;
       collection1.Where(p => p.EntID == c.EntID).FirstOrDefault().Field2 = c.Field2;
       ...
       collection1.Where(p => p开发者_开发问答.EntID == c.EntID).FirstOrDefault().FieldN = c.FieldN;         
    }

EntID is the primary key.

(Under good enough I mean fast and efficient).


   var myItem = collection1.Where(p => p.EntID == c.EntID).FirstOrDefault();
   if (myItem == null)
       continue;
   myItem.Field1 = c.Field1;
   myItem.Field2 = c.Field2;
   ...
   myItem.FieldN = c.FieldN;

If myItem and c are different types, have a look at AutoMapper.


As a complementary answer, you can use reflection to copy the N fields from one object to another. I've already talked about this here: How to refactor this? .

You can have your class (SomeClass) implement this code (both objects are the same class):

public void CopyPropertiesFrom(SomeClass SourceInstance)
{
    foreach (PropertyInfo prop in typeof(SomeClass).GetProperties())
        prop.SetValue(this, prop.GetValue(SourceInstance, null), null);
}

That way, if your class has new properties, you don't have to bother updating the code, it's already there!

For objects with different class, that's also doable via reflection by the property name, but there are some assumptions you have to make (what if property does not exist, what property is different type, what is property value is null, etc.)

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜