考虑这个代码 – 一种可能的解决方案 – 例如:
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# – 有没有更好的方法从其抽象基类调用派生类的重写方法?全部内容,希望文章能够帮你解决c# – 有没有更好的方法从其抽象基类调用派生类的重写方法?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)