c# – 有没有更好的方法从其抽象基类调用派生类的重写方法?
发布时间:2020-12-15 08:24:08 所属栏目:百科 来源:网络整理
导读:我有一个抽象的基类,从中派生出许多类.我希望派生类能够覆盖基类中定义的虚方法,但基类中存在复杂的逻辑,用于确定在任何特定时刻是否“启用”被覆盖的方法. 考虑这个代码 – 一种可能的解决方案 – 例如: public abstract class AbstractBaseClass{ public
我有一个抽象的基类,从中派生出许多类.我希望派生类能够覆盖基类中定义的虚方法,但基类中存在复杂的逻辑,用于确定在任何特定时刻是否“启用”被覆盖的方法.
考虑这个代码 – 一种可能的解决方案 – 例如: 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() (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |