通常,在C#文档中,您会遇到一个成员,其中的描述说明了“如果覆盖它,请务必调用基本方法。”
有没有办法确保在编译时实际调用基函数?
这是一个例子: Implementing a Dispose Method
从第一行开始:
类型的Dispose方法应该释放 它拥有的所有资源。它 还应该释放所有资源 通过调用它的基类型来拥有它 父类型的Dispose方法。
修改
我正在浏览,我看到了这篇文章,看起来很相关。它更像是一个小而不是一个错误,即。它有效用途(如提到的那些):
答案 0 :(得分:8)
您无法强制执行,但您可以通过base.Foo(bar)
之类的通话来执行此操作。 base
允许您访问您继承的类的成员。
您可以使用template method pattern强制执行此行为。例如,假设你有这个代码:
abstract class Animal
{
public virtual void Speak()
{
Console.WriteLine("I'm an animal.");
}
}
class Dog : Animal
{
public override void Speak()
{
base.Speak();
Console.WriteLine("I'm a dog.");
}
}
这里遇到的麻烦是,任何继承自Animal
的类都需要调用base.Speak();
来确保执行基本行为。您可以通过采用以下(略有不同)的方法自动强制执行此操作:
abstract class Animal
{
public void Speak()
{
Console.WriteLine("I'm an animal.");
DoSpeak();
}
protected abstract void DoSpeak();
}
class Dog : Animal
{
protected override void DoSpeak()
{
Console.WriteLine("I'm a dog.");
}
}
在这种情况下,客户端仍然只能看到多态Speak
方法,但保证Animal.Speak
行为可以执行。问题是,如果你有进一步的继承(例如class Dachsund : Dog
),你必须创建另一个抽象方法,如果你希望保证Dog.Speak
能够执行。
答案 1 :(得分:5)
您可以这样称呼它:
public override void MyFunction()
{
// do dome stuff
SomeStuff();
// call the base implementation
base.MyFunction();
}
但是如果你问它是否可以在编译时“检查” - 没有。
您可能可以使用NDepend之类的依赖关系分析工具来创建规则以检查是否已完成,并将规则作为编译的一部分运行,但我认为您无法从编译器本身执行此操作
答案 2 :(得分:0)
单一级别继承的常见模式是提供具有虚拟扩展点的非虚拟模板方法。
protected virtual void ExtensionPoint () { }
public void TemplateMethod () {
ExtensionPoint();
ThisWillAlwaysGetCalled();
}
如果对操作的所有调用都调用了模板方法,那么将调用扩展点的任何覆盖,以及模板方法中始终被调用的代码。