继承需要构造函数的泛型类型的抽象类
本文关键字:泛型类型 抽象类 构造函数 继承 | 更新日期: 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
}
}