C++ virtual继承的另一种名称是菱形继承,主要目的是用于解决从不同类继承来的同名数据成员在内存中有不同的拷贝,造成数据不统一的问题,以致于在进行类释放时造成内存泄漏。将共同的基类作为虚基类,这时从不同的路径继承过来的同名数据成员在内存中就只有一个拷贝,同一个函数名也只有一个映射。这样不仅就解决了二义性问题,也节省了内存,避免了数据不一致的问题。
如下是实现格式:
class 派生类名:virtual 继承方式 基类名 //virtual是关键字,声明该基类为派生类的虚基类。
在多继承情况下,虚基类关键字的作用范围和继承方式关键字相同,只对紧跟其后的基类起作用。声明了虚基类之后,虚基类在进一步派生过程中始终和派生类一起,维护同一个基类子对象的拷贝。由于懒画图引用别人的一个,请大家原谅,谢谢理解:
如下是实现格式:
class 派生类名:virtual 继承方式 基类名 //virtual是关键字,声明该基类为派生类的虚基类。
在多继承情况下,虚基类关键字的作用范围和继承方式关键字相同,只对紧跟其后的基类起作用。声明了虚基类之后,虚基类在进一步派生过程中始终和派生类一起,维护同一个基类子对象的拷贝。由于懒画图引用别人的一个,请大家原谅,谢谢理解:
class CBase
{
public:
CBase(unsigned int len) : m_buffer(0)
{
if(len > 0)
{
m_buffer = new char[len];
}
}
~CBase
{
if(NULL != m_buffer)
{
delete [] m_buffer;
m_buffer = NULL;
}
}
private:
char* m_buffer;
};
class Test1 : public virtual CBase
{
public:
//...
};
class Test2 : public virtual CBase
{
public:
//...
};
class Test3 : public Test1, public Test2
{
public:
//...
};
如果没有虚继承则在对象释放时m_buffer会进行两次释放。