我有这样的情况:
public abstract class BaseClass { public abstract string MyProp { get; } }
现在,对于某些派生类,属性值是一个合成值,所以没有setter:
public class Derived1 : BaseClass { public override string MyProp { get { return "no backing store"; } } }
这工作正常但是,某些派生类需要更传统的后台存储.但是,无论我如何写,如在自动属性或明确的后台存储,我得到一个错误:
public class Derived2 : BaseClass { public override string MyProp { get; private set;} } public class Derived3 : BaseClass { private string myProp; public override string MyProp { get { return myProp;} private set { myProp = value;} } }
Derived2.MyProp.set’:不能覆盖,因为’BaseClass.MyProp’没有可覆盖的集合访问器
如何让这个工作?
解决方法
你可以做的最好的事情是实现属性为虚拟而不是抽象.在基类中为每个抛出的NotSupportedException引发get和set块,并在派生类中相应地覆盖该行为:
public virtual string MyProp { get { throw new NotSupportedException(); } set { throw new NotSupportedException(); } }
原文地址:https://www.jb51.cc/csharp/94619.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。