1、类的成员分为静态成员和实例成员。为什么设计出静态成员和实例成员?
静态成员对类以及类的所有实例有意义,实例成员对每个实例有意义。考虑,Person类,有个age字段和maxAge字段。每个Person实例都有自己的age,但所有的Person实例都有相同的maxAge(最大年龄极限),因此,maxAge只需要一份就好了,大家共享。有两个好处:节约内存和保持一致。
2、成员分为字段和方法,首先考虑字段:
静态字段:只有一块内存。
实例字段:每个实例都有专属于自己的一块内存。
3、对于方法:
无论静态方法和实例方法,只有一块内存。那么问题来了,在成员方法中会使用实例的字段,怎么区分是哪个实例的字段呢?
4、实例成员方法的实现细节:
考虑Person的GetAge方法,int Person::GetAge(),实际上可以认为,该方法在编译后,变成int GetAge(Person* const this)这种形式。也就是说,成员方法编译后变成普通方法,在这个普通方法中,使用this指针。调用方法的时候,使用.或者->调用方法,可认为.或者->前面的这个东西(方法的拥有者),就是普通方法int GetAge(Person* const this)的实参。
5、在考虑一下,为什么int GetAge(Person* const this)中this指针限定为const指针?
考虑,p1.GetAge()中,把this指针指向其他对象,那就不是访问p1的字段了。这显然与程序员意图不一致。调用p1的成员方法,就是访问p1的字段(读取或者写入)。
6、这样,就很好理解const成员方法了。
int Person::GetAge() const 转化为 int GetAge(const Person* const this)
7、const对象只能调用const成员方法,不能调用non-const成员方法,但是non-const对象可以调用const成员方法,也可以调用non-const成员方法。为什么?
可以这样认为:B是A 的别名(引用或者指针),B可以缩小A的能力,但是不能放大A 的能力。
8、static方法中,没有this指针,所有不能使用实例字段。