1.当一个类继承另一个类时。如果父类中有虚函数时。俩个类都有自己的函数数组(虚函数表)子类中的函数数组成员是拷贝父类中的。如果。子类重写父类中的虚函数时。会把重写的虚函数地址。覆盖对应的那个函数数组成员。 2.父类有几个虚表(函数数组)子类也就对应的有自己的虚表。表是各有的不是共享的。但不保证内容一定不同。内容可以相同。 3.子类继承父类。如果子类中有自己独有的虚函数。同时继承了父类的虚表(也就是父类中也有虚函数)。他会把自己独有的虚函数地址。放到从继承顺序的第一个表中。如: ` #include<iostream> #include<string> using namespace std; class bassA{ virtual void fun1(){ cout<<"fun1"<<endl; } }; class bassB{ virtual void fun2(){ cout<<"fun2"<<endl; } }; class bassC{ public: void funC(){ cout<<"funC"<<endl; } }; class sun :public bassA,public bassB//只有俩个虚表 {

virtual void fun3(){  //这个函数地址放在bassA虚表中。不会生成一个新的虚表(函数数组)(按虚表顺序)
    cout<<"sun"<<endl;
}

}; class sun2 :public bassA,public bassB {

virtual void fun1(){  //这个函数地址 覆盖bassA中的fun1的地址也就是改变函数数组中成员的值。
    cout<<"sun2"<<endl;
}

}; class sun3 :public bassC,public bassB { public: virtual void funC(){
cout<<"sun3"<<endl; } }; int main(){ sun3* psun; bassC bac; psun=(sun3*)&bac; psun->funC();//这里会报错bassC类中funC不是虚函数 }

父类指针与子类指针的问题 1.第一步先看动态还是静态联编。 2.如果是静态联编不管你的指针指向谁。它只看指针类型(对象)。什么类型就调用那个类型的函数。 3.动态联编(条件必须是指针。必须是虚函数) 先看你指针类型(对象)的函数是否为虚函数。如果是。它会调用你实际指向的类型(对象)的函数。这里还没有结束。最后会看你的指针指向类型(对象)的函数是否为虚函数。是调用。不是报错。