Я пытаюсь глубоко клонировать следующий класс с помощью 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, но, похоже, делает только поверхностную копию списка деталей. Я попытался добавить .ForMember(d => d.Details, o => o.UseDestinationValue())
, но это не копирует список деталей вообще. Как я могу получить подробный список клонов, т. Е. Получить два совершенно независимых объекта, включая все элементы списка?
ОБНОВЛЕНИЕ: Мне нужно исключить свойство Id, поскольку я использую эти объекты с NHibernate, поэтому не уверен, что решение Serializable сделает это.
ОБНОВЛЕНИЕ2: Изменен вышеуказанный код, чтобы тоже клонировать IList. Кажется, это работает нормально, поскольку я могу исключить свойства, из-за которых NHibernate думает, что он уже сохранен.