我们都知道,C++一个对象占用的内存空间大小取决于类中非静态成员变量所占空间的大小。而静态成员变量,静态成员函数,非静态成员函数都是独存一份,不占用单个对象的空间。
一些C++的初学者或者刚开始学C++的我会有这样的疑惑:同样是独存一份,为什么非静态成员函数能识别不同的对象,能区分自己是被哪个对象调用。而静态成员函数不能识别不同对象,只能对静态成员变量访问呢?
原因很简单,问题就在this指针上:非静态成员函数是独一份的,当我们通过一个具体的对象调用非静态成员函数时,编译器会自动把这个对象的地址当作参数进行传递。
Person p1;
cout << p1.getAge() << endl;
等价于
Person p1;
cout << Person::getAge(&p1) << endl;
于是这个非静态成员函数就得到了对象的地址,就是我们说的this指针,识别到了不同的对象。通过这个指针,自然能对这个对象的内部进行一些访问,我们一切的读写操作都是基于这个this指针的。这就是我们经常写的:
int getAge(){
return this.m_age;
}
然而对于静态成员函数,我们可以采用通过类名调用,也可以用具体的对象的调用,但是这个时候编译器不会把这个具体对象的地址当作参数传递了。也就是说在静态成员函数里是不存在this指针的。没有this指针就像没有进入这个对象的钥匙,我们也不可能对这个对象进行访问,包括读写。但是静态成员变量由于是存储在全局区,不属于某一个对象上,因此静态成员函数能访问静态成员变量。