首先,我已经阅读了有关该主题的帖子列表,并且由于了解封装和字段修饰符(private,public..ect),因此我不了解属性。
我已经学到的C#的主要方面之一是使用封装在代码中保护数据的重要性。我“认为”我理解这是因为使用了修饰符(私有,公共,内部,受保护)的能力。但是,在了解了属性之后,我不仅在理解属性使用方面,而且在理解C#中数据保护的总体重要性/能力(我理解为封装)时也感到困惑。
更具体地说,我在使用C#属性时所读的所有内容是,由于以下原因,您应尝试使用它们代替字段:
1) 它们允许您在直接访问字段时无法更改数据类型。
2) 它们为数据访问添加了一定程度的保护
但是,从我的“想法”开始,我发现使用字段修饰符确实是#2,除非您没有理由更改类型(#1),否则在我看来属性只是生成了附加代码- 因为您是(或多或少)创建隐藏方法来访问字段,而不是直接访问字段。
然后可以将整个修饰符添加到“属性”中,这使我对属性访问数据的需求的理解更加复杂。
我已经阅读了不同作者关于“属性”的许多章节,但没有一章真正说明了对属性vs.字段vs.封装(以及良好的编程方法)的良好理解。
有人可以解释:
1) 为什么我要使用属性而不是字段(特别是当它出现时,我只是添加其他代码
2) 在跟踪其他人的代码时,关于识别属性的使用并且不将其视为简单的方法(除了get; set是显而易见的 )的 任何技巧?
3) 关于什么时候使用什么好的编程方法有什么通用的经验法则?
谢谢,很抱歉,我的帖子很长-我不想只问一个100x的问题,而又不解释为什么再次问这个问题。
您不必担心通过属性访问字段所需的额外代码,它会被JIT编译器“优化”(通过内联代码)。除非它太大而无法内联,否则无论如何您都需要额外的代码。
而且用于定义简单属性的额外代码也很少:
public int MyProp { get; set; } // use auto generated field.
当您需要 自 定义时,您以后总是可以定义自己的字段。
因此,您剩下了额外的封装/数据保护层,这是一件好事。
我的规则: 总是通过属性公开字段