这可能是在泛型类型下的其他地方,但我似乎无法遵循很多答案。如果这是另一个问题的重复,请道歉。
以下代码适用于包含数据,逻辑和演示文稿图层的三层应用
在我的数据层中,我有一个实体集合和一个基本实体
public abstract class BaseEntity
{
int LastModifiedBy { get; set; }
DateTime LastModifiedDate{get;set;}
}
public partial class DocNum: BaseEntity
{
}
public partial class DataList: BaseEntity
{
}
在我的逻辑层中,我有一个用于传输数据的BaseDTO类。这是它的代码
public abstract class BaseDTO
{
protected abstract void ConvertFromEntity(BaseEntity entity);
public abstract void ConvertToEntity();
}
然后我根据它创建实现类DocNum,如下所示
public class DTODocNum : BaseDTO
{
//properties here
public DTODocNum()
{
}
public DTODocNum(DocNum entity)
{
ConvertFromEntity(entity)
}
protected override void ConvertFromEntity(DocNum entity)
{
throw new NotImplementedException();
}
public override void ConvertToEntity()
{
throw new NotImplementedException();
}
}
但是这不会编译告诉我没有找到合适的覆盖方法。 我知道我可以执行以下操作,但我希望此方法只接受数据层中的DocNum实体:
protected override void ConvertFromEntity(BaseEntity entity)
{
throw new NotImplementedException();
}
我还尝试过使用以下
的泛型类型public abstract class BaseDTO
{
protected abstract void ConvertFromEntity<T>(T entity);
public abstract T ConvertToEntity<T>();
}
以及派生类中的以下内容:
protected override void ConvertFromEntity<T>(T entity) where T:DocNum
{
throw new NotImplementedException();
}
但是现在给出的错误是覆盖的约束,显式接口实现方法是从base方法继承的,所以不能直接指定
任何人都可以帮我实现这个解决方案,以便DTODocNum可以在引用实体类型的同时进行编译吗?
答案 0 :(得分:2)
将type参数移动到类级别并添加约束:
public abstract class BaseDTO<T> where T : BaseEntity
{
protected abstract void ConvertFromEntity(T entity);
public abstract T ConvertToEntity();
}
public class DTODocNum : BaseDTO<DocNum> { ... }