前面定义的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.属性可以忽略get或set访问器,但是不能两个都忽略.
示例:
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