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