Я пытаюсь глубоко клонировать следующий класс с помощью AutoMapper:
public class MainData
{
public MainData()
{
Details = new List<Detail>();
}
public int Id { get; private set; }
public DateTime LastUpdate { get; private set; }
public IList<Detail> Details { get; private set; }
public int Prop1 { get; set; }
public int Prop2 { get; set; }
public void AddDetail(Detail detail)
{
Details.Add(detail);
}
public void RemoveDetail(Detail detail)
{
Details.Remove(detail);
}
public MainData Clone()
{
Mapper.Reset();
Mapper.CreateMap<MainData, MainData>().ForMember(d => d.Id, o => o.Ignore());
// Mapper.CreateMap<Detail, Detail>().ForMember(d => d.Id, o => o.Ignore()); // REMOVED
var newMainData = new MainData();
Mapper.Map(this, newMainData);
newMainData.Details = this.Details.Select(item => item.Clone()).ToList(); // ADDED
return newMainData;
}
}
public class Detail
{
public int Id { get; private set; }
public string Name { get; set; }
public double Area { get; set; }
public double Height { get; set; }
public Detail Clone() // ADDED
{
Mapper.CreateMap<Detail, Detail>().ForMember(d => d.Id, o => o.Ignore());
var newDetail = new Detail();
Mapper.Map(this, newDetail);
return newDetail;
}
}
Метод Clone
отлично работает для свойств MainData, но, похоже, делает только мелкую копию списка Details. Я пробовал добавить .ForMember(d => d.Details, o => o.UseDestinationValue())
, но это вообще не копирует список "Подробности". Как я могу получить глубокое клонирование списка Details, т.е. так, чтобы я получил два полностью независимых объекта, включая все элементы списка?
ОБНОВЛЕНИЕ: мне нужно исключить свойство Id, поскольку я использую эти объекты с NHibernate, поэтому не уверен, что решение Serializable сделает это.
ОБНОВЛЕНИЕ 2: приведенный выше код был изменен, чтобы также клонировать IList. Кажется, это работает нормально, поскольку я могу исключить свойства, которые заставляют NHibernate думать, что он уже сохранен.