本文向大家介绍C#属性化的方法,可能好多人还不了解C#属性化的方法,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西。
C#属性化的方法
属性的概念对大家来说应该是很熟悉的,类成员函数可以自由地访问本类中的任何属性成员。不过若要从一个类中去访问另一个类中的属性,那就比较麻烦了,所以很多时候我们使用Getxxx和Setxxx方法,这样看起来显得极不自然,比如用Java或者C++,代码是这样的:
- foo.setSize (getSize () + 1);
- label.getFont().setBold (true);
但是,在C#中,这样的方法被“C#属性化的方法”了。同样的代码,在C#就变成了:
- foo.size++;
- label.font.bold = true;
可以看出来,C#显然更容易阅读和理解。我们从这个“属性方法”的子程序代码中,也可以看到类似情况:
- public int getSize()
- {
- return size;
- }
- public void setSize (int value)
- {
- size = value;
- }
- C#:
- public int Size
- {
- get{return size;}
- set{size = value;}
- }
为了区分这种属性化的方法和类的属性成员,在C#中把属性成员称作“域(field)”,而“属性”则成为这种“C#属性化的方法”专用的名词。顺便说一句,其实这样的C#属性化的方法在VB和DELPHI中是经常碰到的,在VB中它也就叫属性。
另外,在C#中Get和Set必须成对出现,一种属性不能只有Get而没有Set(在Java和C++中就可以只有Get或者只有Set),C#中这样做的好处在于便于维护,假如要对某种属性进行修改,就会同时注意Get和Set方法,同时修改,不会改了这个忘了那个。
【编辑推荐】