- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我很难在 C# 中实现一个在抽象基类中只有 getter 的属性,但我需要在其中一个中引入 setter派生类。
我的类图概述如下所示:
我的目标是 TextElementStatic 和 TextElementReferenceSource 这两个类应该有一个包含 getter 和 setter 的 Text 属性,而类 TextElementReferenceTarget 应该有一个只有 getter 的 Text 属性。我在引用所有这些对象时经常使用 ITextElement,我需要确保 ITextElement 接口(interface)只有一个 getter。此外,基类 TextElement 实现了很多通用代码,因此所有类都需要从该类继承。
我当前的代码如下所示:
接口(interface):ITextElement
public interface ITextElement
{
string Text { get; }
}
接口(interface):ITextElementUpdatable
public interface ITextElementUpdatable : ITextElement
{
new string Text { get; set; }
}
抽象类:TextElement (这是我的问题所在,下面解释)
public abstract class TextElement : ITextElement
{
// I want to mark this 'abstract', but that causes my problem
public virtual string Text
{
get
{
// NOTE: This should never be called
Debug.Fail("Called virtual Text getter that should never be called");
return default(string);
}
}
}
抽象类:TextElementUpdatable
public abstract class TextElementUpdatable : TextElement, ITextElementUpdatable
{
// Should have both a getter and a setter
public new virtual string Text { get; set; }
}
类:TextElementStatic
public class TextElementStatic : TextElementUpdatable
{
// Should have both a getter and a setter
// No Text property declaration
// Inherits Text property from TextElementUpdatable
}
类:TextElementReferenceSource
public class TextElementReferenceSource : TextElementUpdatable
{
// Should have both a getter and a setter
public override string Text
{
get { return _internalobject.Text; }
set { _internalobject.Text = value; }
}
}
类:TextElementReferenceTarget
public class TextElementReferenceTarget : TextElement
{
// Should ONLY have a getter
public override string Text
{
get { return _internalobject.Text; }
}
}
所以,我的问题是:我真的想在基类 TextElement 抽象中声明 Text 属性,因为它应该始终在派生类中实现(TextElementUpdatable、TextElementReferenceSource 和 TextElementReferenceTarget 都实现了这个属性)。但是,如果我尝试将该属性转换为 public abstract string Text { get; }
,然后我在 TextElementUpdatable 中收到错误,指出
TextElementUpdatable.Text hides the inherited property TextElement.Text
此外,如果我将 TextElementUpdatable 中的属性从 new
更改为 override
,错误消息将替换为:
Cannot override because TextElement.Text does not have an overridable set accessor
现在,我可以回到 TextElement 并将属性更改为 public virtual string Text { get;私有(private)集; }
并收工,因为无论如何都不应该调用该方法(这基本上是我现在的解决方案)。但是,如果我或其他人稍后创建另一个派生类,我想强制我/他们实现文本属性,因此我宁愿将其标记为抽象,也不愿提供虚拟实现。
关于如何正确执行此操作的任何建议 - 即使它应该涉及大量重构?
我知道我可以将她的两个目标分开,提供一个仅具有 getter 的继承 Text 属性,然后在 中引入一个 SetText()
方法>ITextElementUpdatable 接口(interface)。但是,我想知道是否可以找到仅具有属性的良好解决方案。
另一个类似的问题,但没有任何答案我已经能够使用:C# - What should I do when every inherited class needs getter from base class, but setter only for ONE inherited class
最佳答案
这确实是一个令人兴奋的设计问题,但是.. 你必须使用 new 关键字这不是一个好的做法。尽量避开它们。当然,接口(interface)中的属性名称可以相同,但如果两者都由一个类实现(并且其中一个属性定义时没有 setter ),我们必须明确地实现它们。我们必须接受这些属性“冲突”。您可以引入抽象方法:
public abstract class TextElement : ITextElement
{
public string Text { get { return GetText(); } }
protected abstract string GetText();
}
public abstract class TextElementUpdatable : TextElement, ITextElementUpdatable
{
string ITextElementUpdatable.Text
{
get { return GetText(); }
set { SetText(value); }
}
protected abstract void SetText(string text);
}
关于c# - 为一些(但不是所有)继承类引入 setter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23833476/
因此,我需要获取在为其赋值时调用的 setter 的名称。像这样: var b = {}; var a = { set hey(value) { b[] = value; } } 我希望 se
我是 Android 编程的新手(~ 2 个月)有必要为几十个不同的变量设置 getter 吗? 例如—— //Yes I realise that this isn't 'dozens' publi
import Control.Lens import Control.Lens.TH data Foo = Foo { _bar, _baz :: Int } makeLenses ''
我有点困惑:我可以覆盖 setter/getter 但仍然使用 super setter/getter 吗?如果是 - 怎么办? 用例: class A { void set value(num
我有一个接收消息的应用程序。消息中存在可编辑的字段。当字段更改时,应将其保存到数据库中。不幸的是,setter 仅在 setter 的范围内更改给定字段的值。知道为什么会发生这种情况吗?这是 gett
C# 中有没有一种方法可以让 setter 从“某物”继承,这样每次为特定基类及其继承者调用 setter 时,我都可以运行一些代码? 我想做的是在我的基类上有一个名为 IsValid 的 bool
可能是一个我无法解决的非常简单的问题 - 我从 C# 开始,需要使用 getter/setter 方法向数组添加值,例如: public partial class Form1 : Form {
这两个属性实现有什么区别? public override string A { get { return "s"; } set { } } public override strin
是否可以使用 abc.abstractproperty 创建一个具体的 getter 但将 setter 抽象为每个继承类的不同。我为每个子类处理不同的 val 设置。 例如。 @abstractpr
我在某处看到类似下面的内容,想知道它是什么意思。我知道他们是getter和setter,但是想知道为什么字符串Type是这样定义的。谢谢你帮助我。 public string Type { get;
Public class Example { private int number; public Example(int number){ this.number =
假设我有这样的代码: public response MyMethod(Request req) { String id = req.getFirst().geId(); } 我已经模拟了主对
允许这样做: public int Age { get; set; } 但是应用程序是否为变量创建/分配空间?我经常这样做 private int age = 0; public int Age {
我有一个条件,我构造字符串 (finalValue) 的方式是基于我在输入中获得的非空值的数量。所以我想知道是否可以用一个不同的参数为字符串 (finalValue) 重载 setter 方法并根据我
例如,在这段代码中 var o = { set a(value) {this.b = value}, get a() {return this.b} } 是否有可能获得对 o.a 的 sett
我一直在努力了解 getter 和 setter,但没有深入了解。我读过 JavaScript Getters and Setters和 Defining Getters and Setters只是没
我想在我的类中添加一个 getter 和 setter。然而,setter 应该接收一个 querySelector,但 getter 返回一个新类型 pageSections。 我的问题是 gett
使用有什么好处: private var _someProp:String; public function set someProp(value:String):void { _somePr
当从域类调用它时,我想在我的 setter 中执行一些操作,而不是从 hibernate 中调用它时。此外,我正在使用 session 工厂,因此我无法使用 @PostLoad 来触发标志! 有人对此
人员类别: public class Person { private String firstName; private String lastName; public Pe
我是一名优秀的程序员,十分优秀!