C++中,在类的继承过程中,会产生基类数据成员的访问二义性问题,虚基类正是在这样的前提下提出的。
将一个基类声明为虚基类的方法入下:
class Son: virtual 访问权限 Father{//注意:virtual只对紧随其后的基类起作用;
//do sth
};
虚基类的构造函数:
与一般类的构造函数不同的地方在于:继承了虚基类的子类必须对虚基类进行初始化。
-------------------------------------------------------------------------------------------------------------------------------------------
#ifndef VIR_H
#define VIR_H
class Base{
private:
int a;
public:
Base(int i);
int getA();
void setA(int aa);
};
class B1 :virtual public Base{
private:
int b1;
public:
B1(int i,int j);
int getB1();
};
class B2 :virtual public Base{
private:
int b2;
public:
B2(int i, int j);
int getB2();
};
class Son :public B1, public B2{
private:
int s;
public:
Son(int s, int b1, int b2, int a);
int getS();
void setA(int aa);
};
#endif
//
#include "Vir.h"
Base::Base(int i){
a = i;
}
int Base::getA(){
return a;
}
void Base::setA(int aa){
a = aa;
}
B1::B1(int i, int j) :Base(j){
b1 = i;
}
int B1::getB1(){
return b1;
}
B2::B2(int i, int j) :Base(j){
b2 = i;
}
int B2::getB2(){
return b2;
}
Son::Son(int s, int b1, int b2, int a) :B1(b1, a), B2(b2, a), Base(a), s(s){}
int Son::getS(){
return s;
}
void Son::setA(int aa){
Base::setA(aa);
}
//
#include "Vir.h"
int main(){
Son s(1, 2, 3, 4);
s.setA(10);
return 0;
}