我们都知道c++中,无法重写静态方法。一般使用的时候记住就可以了。
因为方法不可能既是虚的又是静态的。因此,重写一个静态方法可能都得不到预期的结果。特别是超类中和子类中存在同名的静态方式时,实质上是两个独立的方法。
下面的代码是两个类,有同名的方法beStatic()的静态方法。彼此之间毫无关系:
class SuperStatic{
public:
static void beStatic(){
cout<<"SuperStatic being static."<<endl;
}
};
class SubStatic : public SuperStatic{
public:
static void beStatic(){
cout<<"SubStatic is static"<<endl;
}
};
当我们利用类名调用的时候,出现预期的结果,各自调用自己本类的静态方法:
SuperStatic::beStatic();
SubStatic::beStatic();
结果为:
但当我们准备使用对象来进行调用的时候,情况就比较复杂了。
c++中允许对象调用静态方法,但由于方法为静态没有this指针,也无法访问对象本身,因此使用对象调用的实际效果等同于使用类名调用,classname::method()。
当我们这样调用的时候:
SubStatic mySubStatic;
SuperStatic& ref = mySubStatic;
mySubStatic.beStatic();
ref.beStatic();
出现的结果为下面所示:
出现这样结果的原因在与调用静态方法的时候,c++不在乎对象实际上是什么,其实之间也没有建立起来联系,只关心编译时候的情况,而编译期间的类型和运行期间的类型又可能因为调用对象的不同而有所区别。
编译期间的类型和运行期间的类型判断是造成c++中很多晦涩地方的原因,希望自己能够在今后的学习中不断总结学习。
总结:静态方法属于类,而不属于特定的对象。可以通过类名来解析调用,而对象调用的本质上也不涉及动态绑定,只考虑编译期间的类型,只用来判断类型而已。