建议91:可见字段应该重构为属性
字段和属性的本质区别就是属性是方法。
查看下面这个Person类型:
class Person { public string Name { get; set; } }
经过编译器编译后,针对属性Name实际会生成一个private字段和两个public方法:
[CompilerGenerated] private string <Name>k__BackingField; [CompilerGenerated] public void set_Name(string value) { this.<Name>k__BackingField = value; } [CompilerGenerated] public string get_Name() { return this.<Name>k__BackingField; }
可见,属性实际上是编译器给我们的语法糖。
属性比字段具有以下的优势:
1)可以为属性添加代码。正是因为属性是方法,所以可以在方法内对设置或获取属性的过程进行更多精细化控制。如:为属性添加NameChanged事件等。单凭字段是完成不了这样的功能的。
2)可以让属性支持线程安全。要让属性变成线程安全的可以让类型自身去实现。而要让字段支持线程安全,就只能靠调用者本身来实现了。
3)属性得到VS编译器的支持,还得到了实现自动属性这种功能。自动属性的特点在LINQ中得到了广泛应用,尤其是在匿名类中,它只能实现只读的自动属性,而不支持字段。
4)从设计角度,也就是面向对象角度来看,公开的字段也应该使用属性。改变字段的状态,类型不会被通知到;而改变属性的值,类型支持则会被通知。
综上,如果一个类型存在一个可见字段,那么他应该被重构为属性。当然,如果某个属性仅仅对内部可见,而不涉及以上4点内容,则建议使用字段。
转自:《编写高质量代码改善C#程序的157个建议》陆敏技