您的位置:首页 > 编程语言 > C#

关于C#中静态数据成员和静态方法的总结

2010-03-07 12:24 549 查看
1.静态数据成员:
定义:
使用static关键字定义的数据成员被称为“静态数据成员”。
意义:
静态数据成员所属类的所有实例都共享相同的”静态成员值“。
访问:
实际上,静态成员并不属于某个实例,静态成员属于类。因此,在使用静态成员的时候,不能使用“实例名.静态成员名”的形式,而应该使用“类名.静态成员名”来进行那个访问。原因是因为静态变量没有this指针,只能通过类名引用。
内存分配:
分配时间点 -> 静态数据成员与全局变量相似,它的内存分配发生在应用程序类实例化的时候,即程序运行期间,其释放在程序运行结束时,区别在于其作用域不同。静态数据成员只作用在本文件内。
分配地址 -> 静态变量和方法在静态存储区分配内存,而非静态的在栈区或者堆上分配内存 。

=====================================================================
2.静态方法:
定义:
使用static关键字声明的方法被称为“静态方法”。
访问:
同样是通过类名.方法名来访问。
简述访问规则:
a.静态方法是不属于特定对象的方法,静态方法可以访问静态成员变量,静态方法不可以直接访问实例变量.
如果在静态方法中访问非静态的成员,编译器不会去判断你是通过类直接调用还是通过对象调用,一概认为是非法的,因为他不能确定这个非静态的成员是否被分配了内存,他也懒得去确定。
b.如果静态方法要访问实例变量,只有一种方法:
可以在实例函数调用的情况下,实例变量做为参数传给静态方法。
代码如下: namespace Test
...{
public class TT
...{
private int num = 10;
public void Method1()
...{
TT.Method2(num); //实例函数调用,将实例变量num作用参数传递给了静态方法Method2.
}
public static void Method2(int param) //静态方法
...{
param = param * param;
Console.WriteLine(param);
}
public static void Main()
...{
TT.Method2(10);
TT test = new TT();
test.Method1();
}
}
}
即静态方法可以接受实例变量类型的参数,然后用实例方法包裹静态方法,再传递实例变量到静态方法中。
c.静态方法也不能直接调用实例方法,可以间接调用,首先要创建一个类的实例,然后通过这一特定对象来调用实例方法。
即,静态方法要调用实例方法,只能通过接受对象类型的参数,在方法体内,用对象名.方法名来调用实例方法。
如:
class nbr
...{
//class body;
public void method_nbr()
...{
//method_nbr body;
}
}
class Myapp
...{
static void Myapp_method(nbr object1)
...{
object1.method_nbr();
}
public static void Main()
...{
nbr myobj = new nbr();
Myapp_method(myobj);
}
}

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/iamluole/archive/2008/02/23/2115265.aspx
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: