源码:`#include
#include <stdlib.h>
using namespace std;
class Fu {
public: string num = “父类成员变量;”;
public: virtual void show() {
cout<<(this->num);//因为成员变量没有多态,所以this指向当前类对象的成员变量。
cout<<(this->fun1());//因为方法有多态,所以this指向new对象的方法。
}
public: virtual string fun1() {
cout<<(this->num);//因为成员变量没有多态,所以this指向当前类对象的成员变量。
return "父类调用;";
}
};
class Zi:public Fu {
public: string num = “子类成员变量;”;
public: string fun1() {
cout<<(this->num);//因为成员变量没有多态,所以this指向当前类对象的成员变量。
return "子类调用;";
}
};
int main()
{
Fu *f = new Zi();
cout<<(f->num);//这里定义的是父类,而成员变量没有多态,所以即使你new的子类,依然指向父类的成员变量。
cout<<(f->fun1());//不解释了,就是多态。
f->show();
return 0;
}`
运行结果:
父类成员变量;子类成员变量;子类调用;父类成员变量;子类成员变量;子类调用;
结论:
多态:1.类的成员函数的覆盖,new谁就调用谁,这就是多态;
2.类的成员变量的覆盖,指针是哪个类型的,this就是那类型的,没有多态
this是指向当前对象的地址的。