zoukankan      html  css  js  c++  java
  • [.net 面向对象编程基础] (10) 类的成员(字段、属性、方法)

    [.net 面向对象编程基础] (10) 类的成员(字段、属性、方法)

     

     前面定义的Person的类,里面的成员包括:字段、属性、方法、事件等,此外,前面说的嵌套类也是类的成员。 

      a.类的成员为分:静态成员(static)和非静态成员 

      b.静态成员用static标识,不标识则默认为非静态成员 

      c.静态成员属于类所有,动态成员则属于实例所有,即对象 

      d.静态成员为类所有实例共享,无论类有多少实例或副本,静态成员只占用存中一块区域。非静态成员则在类的每个实例,都创建一个内存域。    

     

    下面主要说明一下类的主要成员:字段、属性、方法 

     

    1.类的成员——字段(field) 

       字段声明:(static/readonly) <Type> <变量名称>    

       a.可以理解为类的一个私有变量,通常都是私有的(private)。 

       b.字段的定义通常以小写字母开头或 “_” 开头。 

       c.字段声明修饰符有static(静态)和readonly(只读)两种。 

       d字段通常为私有,因此一般不需要使用访问修饰符. 

       示例:     

    1    static int eyesCount=2;
    2    readonly int earsCount=2;  

      

    2.类的成员——属性(property) 

       a.可以理解为类的一个公有变量,通常都是公有的(public) 

       b.属性有get 和 set 两个方法。 

       c.get 访问器返回与属性声明类型相同的数据, 表示的意思是调用时可以得到内部的字段的值或引用。 

       d.set 访问器没有显示设置的参数,它有一个隐式参数value    它的作用是调用时,可以给属性内部字段或引用赋值。 

       e.由于类的成员默认为私有,因为根据属性为公有的特征,在面向对象开发过程中,要使用修饰符public来声明一个属性为公有。 

       f.属性可以忽略getset访问器,但是不能两个都忽略. 

       示例:     

     1 string _country;
     2 //读写属性
     3  public  string Country
     4 {
     5     set { _country = value; }
     6     get { return _country; }
     7 }
     8 //只读属性
     9 public  string CountryOnleread
    10 {
    11     get { return _country; }
    12 }        
    13 //只写属性
    14 public  string Countryonlywrite
    15 {
    16     set { _country = value; }
    17 }

     

    6.类的成员——方法 (Method ) 

          声明:(访问修饰符) <类型> <方法名>{方法体} 

         调用:[<类名.>]|[<实例对象名.>]<方法名>([<实参列表>]) 

         定义:是类中用于执行计算或其它行为的成员

    静态方法:
         方法分为实例方法和静态方法(同前面讲的类的成员) 

         静态方法中只能调用静态字段,不允许调用非静态字段 

    方法参数:

          值参数:不含任何修饰符。方法中的形参是实参的一份拷贝,形参的改变不会影响到内存中实参的的值,实参是安全的。 

         引用参数:以ref修饰符声明。 

        ref 关键字使参数按引用传递。其效果是,当控制权传递回调用方法时,在方法中对参数所做的任何更改都将反映在该变量中。
        若要使用 ref 参数,则方法定义和调用方法都必须显式使用 ref 关键字。
        传递到 ref 参数的参数必须最先初始化。这与 out 不同,out 的参数在传递之前不需要显式初始化。
        属性不是变量,因此不能作为 ref 参数传递。
        尽管 ref 和 out 在运行时的处理方式不同,但它们在编译时的处理方式是相同的。因此,如果一个方法采用 ref 参数,而另一个方法采用 out 参数,则无法重载这两个方法。例如,从编译的角度来看,以下代码中的两个方法是完全相同的。如果尝试这么做,将导致不能编译该代码。
        如果一个方法采用 ref 或 out 参数,而另一个方法不采用这两类参数,则可以进行重载。

       代码示例: 

    //调用
    double[] numbers = new double[] { 1, 2, 3, 5.5 };
    double i = 0;
    MyAddOperation(numbers, ref i);            
    Console.WriteLine("计算结果的2倍是:{0}",i*2);
    Console.ReadLine();
    
    //引用参数方法声明
    public static void MyAddOperation(double[] numbers, ref double result)
    {
        result = 0;
        foreach (double num in numbers)
            result += num;
        Console.WriteLine("计算结果是:{0}", result);
    }

      

     输出参数:以out修饰符声明。和ref类似,它也是直接对实参进行操作。在方法声明和方法调用时都必须明确地指定out关键字。out参数声明方式不要求变量传递给方法前进行初始化,因为它的含义只是用作输出目的。但是,在方法返回前,必须对out参数进行赋值。 
    out 关键字会导致参数通过引用来传递。这与 ref 关键字类似。 


    与 ref 的不同之处: 
    ref 要求变量必须在传递之前进行初始化。 
    尽管作为 out 参数传递的变量不需要在传递之前进行初始化,但需要调用方法以便在方法返回之前赋值。 

    示例: 

     1 //调用
     2 double[] numbers = new double[] { 1, 2, 3, 5.5 };
     3 double i = 0;
     4 MyAddOperation(numbers, out i);            
     5 Console.WriteLine("计算结果的2倍是:{0}",i*2);
     6 Console.ReadLine();
     7 
     8 //输出参数方法声明
     9 public static void MyAddOperation(double[] numbers, out double result)
    10 {
    11     result = 0;
    12     foreach (double num in numbers)
    13         result += num;
    14     Console.WriteLine("计算结果是:{0}", result);
    15 }

     

     数组型参数:以params修饰符声明。params关键字用来声明可变长度的参数列表。方法声明中只能包含一个params参数。params 参数在参数数目可变的情况下,非常有用,看下面的示例:

     

     1 //调用方法
     2 double[] numbers = new double[] { 1, 2, 3, 5.5 };
     3 Console.WriteLine("计算结果是:{0}", MyAddOperation(numbers));
     4 
     5 //数组型参数声明
     6 public static double MyAddOperation(params double[] numbers)
     7 {
     8     double result = 0;
     9     foreach (double num in numbers)
    10         result += num;
    11     return result;
    12 }

     

    Virtual方法(虚方法) 

         virtual 关键字用于在基类中修饰方法。virtual的使用会有两种情况:  

        情况1:在基类中定义了virtual方法,但在派生类中没有重写该虚方法。那么在对派生类实例的调用中,该虚方法使用的是基类定义的方法。 

        情况2:在基类中定义了virtual方法,然后在派生类中使用override重写该方法。那么在对派生类实例的调用中,该虚方法使用的是派生重写的方法。 

    Abstract方法(抽象方法) 

         abstract关键字只能用在抽象类中修饰方法,并且没有具体的实现。抽象方法的实现必须在派生类中使用override关键字来实现。 

    (关于抽象类,在后面会详细说明)

     

    要点: 

    1.静态方法中只能调用静态字段,不允许调用非静态字段 

    2. 无返回值的方法,类型为 void  

     

    ==============================================================================================

                                                                                                       返回目录

    ==============================================================================================

  • 相关阅读:
    CAN总线(1)--初探(更新中)
    无约束时钟导致综合实现效果不一致
    推荐几本FPGA书籍(更新中)
    Ubuntu下配置支持Windows访问的Samba共享
    svn 节点处冲突 解决
    clock()、time()、clock_gettime()和gettimeofday()函数的用法和区别
    Linux入门,这七大习惯得有!
    Ubuntu硬盘空间不足时,添加硬盘的方法
    让你快速学会Shell脚本
    printf与fprintf函数的区别
  • 原文地址:https://www.cnblogs.com/yubinfeng/p/4552717.html
Copyright © 2011-2022 走看看