【转】浅析C# get set的简单用法

    在属性声明中,C# get set访问器都必须在属性体的内部声明。使用get访问器更改对象的状态是一种错误的编程样式。

    关于C# get set的文章很多,但是笔者的这篇文章有它的特别之处,笔者用简单的语言把c# get set讲述的十分明了。

    C# get set释一:属性的访问器包含与获取(读取或计算)或设置(写)属性有关的可执行语句。

    访问器声明可以包含get 访问器或set 访问器,或者两者均包含。声明采用下列形式之一:get {}set {} get 访问器  get 访问器体与方法体相似。它必须返回属性类型的值。执行 get 访问器相当于读取字段的值。以下是返回私有字段 name 的值的 get 访问器:

    1. private string name;   // the name field  
    2. public string Name   // the Name property  
    3. {     
    4.     get    {      return name;    }  
    5. }   

    当引用属性时,除非该属性为赋值目标,否则将调用 get 访问器读取该属性的值。例如:Employee e1 = new Employee();...Console.Write(e1.Name);   // The get accessor is invoked here  get 访问器必须在return或throw 语句中终止,并且控制不能超出访问器体。set 访问器set 访问器与返回 void 的方法类似。它使用称为 value 的隐式参数,此参数的类型是属性的类型。

    在下例中,set 访问器被添加到 Name 属性:

    1.  public string Name  
    2.  {     
    3.      get    {       return name;    }    
    4.      set    {      name = value;    }  
    5. }  

    当对属性赋值时,用提供新值的参数调用 set 访问器。例如:e1.Name = "Joe";   // The set accessor is invoked here在 set 访问器中对局部变量声明使用隐式参数名 (value) 是错误的。

    C# get set备注:

    属性按如下方式,根据所使用的访问器进行分类:只带有get 访问器的属性称为只读属性。无法对只读属性赋值。只带有 set 访问器的属性称为只写属性。只写属性除作为赋值的目标外,无法对其进行引用。同时带有 get 和 set 访问器的属性为读写属性。

    在属性声明中,get 和set 访问器都必须在属性体的内部声明。使用 get 访问器更改对象的状态是一种错误的编程样式。例如,以下访问器在每次访问 number 字段时都产生更改对象状态的副作用。

    1. public int Number   
    2. {     
    3.    get   {      return number++;   // Don't do this   }  
    4. }  

    可以将 get 访问器用于返回字段值,或用于计算字段值并将其返回。例如:

    1. public string Name   
    2.      
    3.    get    {      return name != null ? name : "NA";   }  

    在上述代码段中,如果不对 Name 属性赋值,它将返回值 NA。示例 1此例说明如何访问基类中被派生类中具有同一名称的另一个属性隐藏的属性。

    1. // property_hiding.cs  
    2. // Property hidingusing System;  
    3. public class BaseClass   
    4. {    
    5.    private string name;    
    6.    public string Name     
    7.   {       
    8.       get       {         return name;       }    
    9.       set       {         name = value;       }   
    10.   }  
    11. }  
    12. public class DerivedClass : BaseClass   
    13. {     
    14.     private string name;    
    15.     public new string Name   // Notice the use of the new modifier    
    16.    {      
    17.         get       {         return name;       }      
    18.         set       {         name = value;       }    
    19.   }  
    20. }  
    21. public class MainClass   
    22. {  
    23.    public static void Main()    
    24.    {  
    25.      DerivedClass d1 = new DerivedClass();      
    26.      d1.Name = "John"// Derived class property       
    27.      Console.WriteLine("Name in the derived class is: {0}",d1.Name);      
    28.      ((BaseClass)d1).Name = "Mary"// Base class property      
    29.      Console.WriteLine("Name in the base class is: {0}",         ((BaseClass)d1).Name);     
    30.   }  
    31. }  

    输出Name in the derived class is: JohnName in the base class is: Mary以下是上例中显示的重点: 派生类中的属性 Name 隐藏基类中的属性 Name。在这种情况下,派生类的该属性声明使用 new 修饰符:    public new string Name    {   ...转换 (BaseClass) 用于访问基类中的隐藏属性: ((BaseClass)d1).Name = "Mary";

    C# get set释二: 代码如下:

    1. public class Car  
    2. {  
    3.     private string color;   
    4.     public string Color   
    5.     {    
    6.           get   {return color;    }    
    7.           set    {color=value;    }  
    8.    }  
    9. }  

    我的理解是:通过GET和SET对公有变量Color进行读写操作,实际就是间接更改color私有变量的值,那既然如此。为何不设color为public,让实例直接对color进行读写操作呢? 如果有一天,老板让你把这个类改成当汽车的颜色改变时,同时计算一下汽车的《价格》属性那么如果直接对Color操作,你不是死定了?  “属性”是.net的特色之一。

    其实就相当于方法,尤其是java中经常会用到get、set方法(.net的有些思想就是java的)。  属性的真实作用不只是为了更改某个成员变量的值比如form的size属性在set的同时要重画form,如果你不想让用户对color修改,就不要提供C# get set方法  是面向对象具有的set and get它的用途:  一般是对类里面的变量进行操作. 而不是直接对类的变量进行操作.

    有一个很大的作用就是:  便于维护.因为:如果一个类的一个变量int a ,在其它包或命名空间类中使用了1000次,但是过了许久,你想把a改为b,如果直接对变量a操作的话,就得需求修改整个程序的1000处.  如果用属性了,就不会了,只需改这个方法即可public int A{ set {   a = value; } get {   return a; }}放为:public int B{ set {   b = value; } get {   return b; }}除去这个属性之外的地方根本不需要改变。

    通过上面的讲解。有一点点明白了。是不是让满足一定条件让GET和SET来改变类中的私有变量。而不能让实例直接操作。像上面的代码保证了color属性的安全性。既然如此可不可以写成set{color=value*20;  //value是不是相当于Color的值} 我当初和你有一样的想法.但是现在改变了。举个例子说明一下吧.

    1. public class Car  
    2. {   
    3.    public string Color  
    4.  {     
    5.      get   {      
    6.                    ifthis.viewstate["color"]!= null)     
    7.                   {        
    8.                          return this.viewstate["color"];       
    9.                   }      
    10.                         return "":      
    11.             }      
    12.     set    {      this.viewstate["color"];=value;    }   
    13.   }  
    14. }    

    在asp.net中通常这么使用.如果用变量的话就不好使用了。而且C# get set中可以写多个语句。

posted @ 2011-05-05 20:01  AndreMouche  阅读(808)  评论(0编辑  收藏  举报