[英]Abstract class inheriting a generic type requiring a constructor
我创建了一些类如下:
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
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.