В Поваренной книге NHibernate 3.0 есть образец реализации для базового типа Entity. Equals реализован следующим образом:
public abstract class Entity<TId>
{
public virtual TId Id { get; protected set; }
public override bool Equals(object obj)
{
return Equals(obj as Entity<TId>);
}
private static bool IsTransient(Entity<TId> obj)
{
return obj != null && Equals(obj.Id, default(TId));
}
private Type GetUnproxiedType()
{
return GetType();
}
public virtual bool Equals(Entity<TId> other)
{
if (other == null) return false;
if (ReferenceEquals(this, other)) return true;
if (!IsTransient(this) && !IsTransient(this) && Equals(Id, other.Id))
{
var otherType = other.GetUnproxiedType();
var thisType = GetUnproxiedType();
return thisType.IsAssignableFrom(otherType) ||
otherType.IsAssignableFrom(thisType);
}
return false;
}
}
Причина использования метода GetUnproxiedType () заключается в следующем: существует абстрактный базовый класс Product, конкретный класс Book, который наследуется от Product, и динамический прокси-класс ProductProxy, используемый NHibernate для отложенной загрузки. Если ProductProxy, представляющий Книгу и конкретную Книгу, имеют одинаковые идентификаторы, их следует рассматривать как равные. Однако я действительно не понимаю, почему вызов GetType () в экземпляре ProductProxy должен возвращать Product в этом случае и как это помогает. Есть идеи?