继承需要构造函数的泛型类型的抽象类

本文关键字:泛型类型 抽象类 构造函数 继承 | 更新日期: 2023-09-27 18:35:05

我创建了一些类,如下所示:

abstract class TestBase<T, TThis> where TThis : TestBase<T, TThis>, new()
{
    public T Thing { get; set; }
    public static TThis CreateNew(T t)
    {
        return new TThis {Thing = t};
    }
}
abstract class MiddleClass : TestBase<string, MiddleClass>
{
    public abstract void DoSomething();
}
class RealClass : MiddleClass
{
    public override void DoSomething()
    {
        // do something
    }
}
...
var mc = RealClass.CreateNew("Hello world");
mc.DoSomething();

如您所见,使用此模式,我可以模拟静态方法CreateNew()的一种继承,该方法返回调用的TestBase子类的类型。 非常适合派生自TestBase的具体类。

麻烦的是,在这种特殊情况下,它不会编译,因为MiddleClass是抽象的,因此没有无参数构造函数来满足new()约束。

除了使MiddleClass具体之外,您还能想到解决方法吗?

继承需要构造函数的泛型类型的抽象类

你也可以

MiddleClass泛型:

abstract class MiddleClass<T> : TestBase<string, T> where T : MiddleClass<T>, new()
{
    public abstract void DoSomething();
}

RealClass定义为:

class RealClass : MiddleClass<RealClass>
{
    public override void DoSomething()
    {
        // do something
    }
}

让你的中产阶级通用

    abstract class TestBase<T, TThis> where TThis : TestBase<T, TThis>, new()
    {
        public T Thing { get; set; }
        public static TThis CreateNew(T t)
        {
            return new TThis { Thing = t };
        }
    }
    abstract class MiddleClass<TThis> 
         : TestBase<string, TThis> where TThis : TestBase<string, TThis>, new()
    {
        public abstract void DoSomething();
    }
    class RealClass : MiddleClass<RealClass>
    {
        public override void DoSomething()
        {
            // do something
        }
    }