C#中静态方法和实例化方法的区别
1个回答
展开全部
最近使用C#进行文件操作遇到静态方法和实例化方法的问题,搜了一下资料,记录如下:
静态方法和非静态方法的区别:
1.静态方法不需要类实例化就可以调用,但是非静态方法需要实例化后才能调用;
2.静态方法只能访问静态成员和静态方法,非静态方法都可以访问;
3.静态方法不能标记为override,导致派生类不能重写,但是可以访问;
4.静态成员是在第一次使用时进行初始化(是初始化而非实例化)。非静态的成员是在创建对象的时候进行初始化。从内存分配上来说静态是连续的,非静态在内存的存储上是离散的,因此静态方法和非静态方法,在调用速度上,静态方法速度一定会快点,因为非静态方法需要实例化,分配内存,但静态方法需要,但是这种速度上差异可以忽略不计。
何时用静态方法,何时用实例方法:
1.一个方法和他所在类的实例对象无关,不依赖new出来的实例,那么它就应该是静态的
2.不需要面向对象的理念的时候用静态;比如动物-> RUN ,因为你可能会扩展出猫 run、狗 run,这时候就需要用非静态的方法
关于线程安全:
静态方法只有一个实例,当有静态变量的时候,对于高并发的时候,并发的所有执行都走那个方法,静态变量的值就会发生改变,导致出现问题;
当然并发不安全跟方法本身没关系,跟共享的那个资源有关系比如某个变量,每个线程都对其进行操作,都能改变其值,多线程(并发其实就是多线程),操作它,其值混乱,就有问题了。
为什么要用非静态方法
1.因为方法需要重复的调用,每次都去new一次会造成内存的开销,使用静态的方法就会一直在内存中,不需要重新new一块空间初始化数据;
2.方法不依赖new出来的内容。
静态方法和非静态方法的区别:
1.静态方法不需要类实例化就可以调用,但是非静态方法需要实例化后才能调用;
2.静态方法只能访问静态成员和静态方法,非静态方法都可以访问;
3.静态方法不能标记为override,导致派生类不能重写,但是可以访问;
4.静态成员是在第一次使用时进行初始化(是初始化而非实例化)。非静态的成员是在创建对象的时候进行初始化。从内存分配上来说静态是连续的,非静态在内存的存储上是离散的,因此静态方法和非静态方法,在调用速度上,静态方法速度一定会快点,因为非静态方法需要实例化,分配内存,但静态方法需要,但是这种速度上差异可以忽略不计。
何时用静态方法,何时用实例方法:
1.一个方法和他所在类的实例对象无关,不依赖new出来的实例,那么它就应该是静态的
2.不需要面向对象的理念的时候用静态;比如动物-> RUN ,因为你可能会扩展出猫 run、狗 run,这时候就需要用非静态的方法
关于线程安全:
静态方法只有一个实例,当有静态变量的时候,对于高并发的时候,并发的所有执行都走那个方法,静态变量的值就会发生改变,导致出现问题;
当然并发不安全跟方法本身没关系,跟共享的那个资源有关系比如某个变量,每个线程都对其进行操作,都能改变其值,多线程(并发其实就是多线程),操作它,其值混乱,就有问题了。
为什么要用非静态方法
1.因为方法需要重复的调用,每次都去new一次会造成内存的开销,使用静态的方法就会一直在内存中,不需要重新new一块空间初始化数据;
2.方法不依赖new出来的内容。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询