废话少说,直接上测试代码
#include<iostream>
#include<stdlib.h>using namespace std;
//有虚函数的类
class A
{
public:
A();
~A();
virtual void f(){
cout<<"this is A f()"<<endl;
}
virtual void g()
{
cout<<"this is A g()"<<endl;
}
private:
int _a;
};
class B:public A
{
public:
B();
~B();
void g()
{
cout<<"this is B g()"<<endl;
}
private:
int _b;
};
B::B()
{
}
B::~B()
{
}
A::A()
{
this->_a = 123;
}
A::~A()
{
}
int main()
{
B b;
A a;
b.f();
/b.g();
cout<<"sizeof(a):"<<sizeof(a)<<endl;//_a,虚指针
cout<<"sizeof(b):"<<sizeof(b)<<endl;// _a,_b ,虚指针
cout<<"sizeof(A)"<<sizeof(A)<<endl;//
cout<<"sizeof(B)"<<sizeof(B)<<endl;//
system("pause");//
return 0;//
}
/*
每个含有虚函数的类中有一个虚函数表,其中每一项都是虚函数的地址。
*/
打印结果:
this is A f()
this is B g()
sizeof(a):8
sizeof(b):12
sizeof(A)8
sizeof(B)12
//结果解释:
第一行的解释:B类对象调用基类的方法
第二行的解释:A类重写了B类的方法,故B类的对象调用了本省的方法。
第三行到第六行:含有虚函数的类:都包含一个虚指针指向一个虚函数表,虚函数表中存放的是对应的虚函数的地址,子类若重写了父类的函数,则子类的对象调用的是子类的方法(这是在存在虚函数的情况之下);
扩展:父类的对象赋值给子类对象,父类的指针或者引用赋值给子类也是非法的;
在没有虚函数的情况下,父类的指针或者引用指向子类的对象,父类的指针是不能调用子类的方法的。在存在虚函数的情况 下是可以调用子类重写父类的方法;仍然不可以调用子类没有从父类继承的函数。
这就是c++实现多态的一种方法。