一尘不染

属性与字段:需要帮助来掌握属性在字段上的使用

c#

首先,我已经阅读了有关该主题的帖子列表,并且由于了解封装和字段修饰符(private,public..ect),因此我不了解属性。

我已经学到的C#的主要方面之一是使用封装在代码中保护数据的重要性。我“认为”我理解这是因为使用了修饰符(私有,公共,内部,受保护)的能力。但是,在了解了属性之后,我不仅在理解属性使用方面,而且在理解C#中数据保护的总体重要性/能力(我理解为封装)时也感到困惑。

更具体地说,我在使用C#属性时所读的所有内容是,由于以下原因,您应尝试使用它们代替字段:

1) 它们允许您在直接访问字段时无法更改数据类型。

2) 它们为数据访问添加了一定程度的保护

但是,从我的“想法”开始,我发现使用字段修饰符确实是#2,除非您没有理由更改类型(#1),否则在我看来属性只是生成了附加代码-
因为您是(或多或少)创建隐藏方法来访问字段,而不是直接访问字段。

然后可以将整个修饰符添加到“属性”中,这使我对属性访问数据的需求的理解更加复杂。

我已经阅读了不同作者关于“属性”的许多章节,但没有一章真正说明了对属性vs.字段vs.封装(以及良好的编程方法)的良好理解。

有人可以解释:

1) 为什么我要使用属性而不是字段(特别是当它出现时,我只是添加其他代码

2) 在跟踪其他人的代码时,关于识别属性的使用并且不将其视为简单的方法(除了get; set是显而易见的 )的 任何技巧?

3) 关于什么时候使用什么好的编程方法有什么通用的经验法则?

谢谢,很抱歉,我的帖子很长-我不想只问一个100x的问题,而又不解释为什么再次问这个问题。


阅读 273

收藏
2020-05-19

共1个答案

一尘不染

您不必担心通过属性访问字段所需的额外代码,它会被JIT编译器“优化”(通过内联代码)。除非它太大而无法内联,否则无论如何您都需要额外的代码。

而且用于定义简单属性的额外代码也很少:

public int MyProp { get; set; } // use auto generated field.

当您需要 定义时,您以后总是可以定义自己的字段。

因此,您剩下了额外的封装/数据保护层,这是一件好事。

我的规则: 总是通过属性公开字段

2020-05-19