关于在C#中使用 “字段编辑器” 的说明
当需要在一个类中使用某个字段并进行get和set时,在java中我们通常的办法是首先定义相应的属性,如:name,然后添加对应的getter和setter方法,以得到封装属性,暴露方法的目的。在C#中有一种比较简便的方法做到,例如在一个类中有name,age,team三个字段(属性),那么我们可以这样定义:
public String Name {set;get;}
public int Age {set;get;}
public String Team {set;get;}
通过以上三句,经过编译器的编译,可以变成如下代码:
private String Name;
public void setName(String value)
{
this.Name = value;
}
public String getName()
{
return this.Name;
}
。。。
类实例在调用时可以通过:obj.Name直接调用,相当于执行:obj.getName() 或者 obj.setName(value)
可以看出,C#在这方面的代码是非常简洁的,但是只是这样写会给类生成实例时带来麻烦,因为没有自定义构造函数,不能使用new ClassName(xx,xx,xx)的形式来生成实例,但可以通过new ClassName(){Name = "";Age = "";Team=""}
生成(看起来挺别扭的吧……),如果希望使用构造函数来生成实例的话只能修改对应的get;set;方法就可以了,这样一来又麻烦了……
从上面的情况,我们可以看出,C#的编译器在将代码编译成IL的过程中确实做了不少的事情,可能微软的目的就是让代码看起来更加的简洁,更加接近人类语言吧(这点我是从LINQ的学习中体会到的,呵呵……),好了,今天就写到这儿,以上是我在学习中体会到的一点点,平时做Java,因为项目需要才开始学习C#的东西,如果有理解错误的地方,欢迎各位.Net高手留言指正。