使用派生类型实现抽象类

时间:2015-01-14 12:51:56

标签: c# interface polymorphism derived-types

这可能是在泛型类型下的其他地方,但我似乎无法遵循很多答案。如果这是另一个问题的重复,请道歉。

以下代码适用于包含数据,逻辑和演示文稿图层的三层应用

在我的数据层中,我有一个实体集合和一个基本实体

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可以在引用实体类型的同时进行编译吗?

1 个答案:

答案 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> { ... }