本帖最后由 杨正 于 2012-10-17 15:40 编辑
main方法为什么要定义成静态方法,首先我们要了解什么事静态方法,什么是非静态方法。定义百度百科有。
这里分析一下二者的区别:
一、
1、静态成员属于类所有,非静态成员属于类的实例所有。
2、每创建一个类的实例,都会在内存中为非静态成员新分配一块存储;静态成员属于类所有,为各个类的实例所公用,无论类创建了多少实例,类的静态成员在内存中只占同一块区域。
(在这一点上,main 方法就必须定义成静态了,因为属于program类所有,而不是某一个实例对象所有。)
二、
1、非静态方法可以访问类中的任何成员,静态方法只能访问类中的静态成员。(main方法的访问成员当然也要包括非静态方法咯)
2、因为静态方法在类实例化前就可以使用,而类中的非静态变量必须在实例化之后才能分配内存, 这样,C#静态方法调用时无法判断非静态变量使用的内存地址。所以无法使用。而静态变量的地址对类来说是固定的,故可以使用。
三、
1、C#静态方法是一种特殊的成员方法 它不属于类的某一个具体的实例,而是属于类本身。所以对静态方法不需要首先创建一个类的实例,而是采用类名.静态方法的格式。
2、.static方法是类中的一个成员方法,属于整个类,即不用创建任何对象也可以直接调用!
3、static内部只能出现static变量和其他static方法!而且static方法中还不能使用this....等关键字..因为它是属于整个类!
4、静态方法效率上要比实例化高,静态方法的缺点是不自动进行销毁,而实例化的则可以做销毁。
5、静态方法和静态变量创建后始终使用同一块内存,而使用实例的方式会创建多个内存。
希望能帮到你。 |