c# – 有没有更好的方法从其抽象基类调用派生类的重写方法?

前端之家收集整理的这篇文章主要介绍了c# – 有没有更好的方法从其抽象基类调用派生类的重写方法?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个抽象的基类,从中派生出许多类.我希望派生类能够覆盖基类中定义的虚方法,但基类中存在复杂的逻辑,用于确定在任何特定时刻是否“启用”被覆盖的方法.

考虑这个代码 – 一种可能的解决方案 – 例如:

public abstract class AbstractBaseClass
{
  public bool IsMethodEnabled { get; set; }

  public virtual void DerivedMethod() { }

  public void Method()
  {
    if (IsMethodEnabled)
      DerivedMethod();
  }
}

public class DerivedClass : AbstractBaseClass
{
  public override void DerivedMethod()
  {
    Console.WriteLine("DerivedMethod() was called.");
  }
}

在上面的例子中,IsMethodEnabled是更复杂的逻辑的简写,它确定是否应该调用DerivedMethod – 它是我想要封装在基类中的代码,这样我就不必在每个派生类中重现它.

设计按预期工作.如果我运行此示例代码

AbstractBaseClass a1 = new DerivedClass() { IsMethodEnabled = false };
AbstractBaseClass a2 = new DerivedClass() { IsMethodEnabled = true };

a1.Method();
a2.Method();

……正如预期的那样,我看到了对DerivedMethod的一次调用.

但有些事情让我觉得这个实现错了.我觉得必须有更优雅的方式来处理这个问题.有没有更好的方法从其抽象基类中有选择地调用派生类的方法实现?有没有一种设计模式可以更好地为我服务?

换句话说,上面的代码“闻”了吗?

解决方法

这是一个非常合理的实现.

我建议的主要变化是:

>使实现受保护功能的虚拟方法而不是公共方法>为此使用更合适的命名.也许更像是public void Method()和protected virtual void OnMethod()

猜你在找的C#相关文章