c++为什么要有静态函数
发布网友
发布时间:2022-10-13 21:19
我来回答
共3个回答
热心网友
时间:2023-11-13 19:42
因为静态函数始终只有一个实例
C++类中的静态成员有一个非常好的功能,那就是无论类定义了多少个对象,这些对象始终都共同使用这一个静态成员
例如: class A{
static int num;
A(){num++} }
int A::num=0;
就会有如下效果: A a,b,c,d; cout<<a.num<<","<<b.num<<","<<c.num<<","<<d.num 输出 4,4,4,4
可以看出,在每个对象中的num成员都只有一个副本。在内存中也是如此,初始化abcd时并没有分配新的内存。
在使用静态成员的过程中还有以下几点注意:
1.num不可以在类中初始化,更不可以在构造函数或构造函数初始化表中初始化。必须在类外初始化。方法是:
int A::num=0; 此时不能有对象被定义,也就是说县定义num才可以,定义a b等
2.如果num为public成员,那么任何时候都可以这样调用它 A::num 当然 a.num也可以
对于静态成员函数,它的特点和静态数据成员相似但也有不同:
class A{
int num;
A(){num++}
static int p(){return num; } }//wrong
1.可以在类中定义。这一点与静态数据成员不同
2.若p()为public成员,则可以这样调用A::p()。这一点与静态数据成员相同。
3.静态成员函数不属于任何一个特定的对象,所以不存在隐含的this指针。如果要在函数中访问某个特定的对象的成员,必须结合使用操作符“.”或“->”来显示地制定所属对象。
4上面所给的程序是错误的因为num不属于所有的对象。如果num是静态的则可以。
静态成员函数常用来操作静态数据成员。
热心网友
时间:2023-11-13 19:42
类的设计者是想把这些函数与整个类在概念上关联起来。
当然它也可以与静态数据成员结合使用来产生一些特殊的技巧,详见相关书籍。
参考资料:THINKING IN C++
热心网友
时间:2023-11-13 19:43
存在即合理