c++基礎(chǔ)語(yǔ)法:虛繼承
虛繼承 的概念的提出主要是為了解決C++多繼承的問(wèn)題,舉個(gè)最簡(jiǎn)單的例子:
class animal{
public :
void op()
{cout << "hello animal" ;}
};
class tiger : public animal {
public :
void tg()
{cout << "this is tiger" ;}
};
class lion : public animal {
public :
void lo()
{cout << "this is lion" ;}
};
class liger : public tiger, public lion {
public :
void lo()
{cout << "this is lion" ;}
};
int main()
{
class liger oneliger ;
liger.op() ;
}
上面的 liger.op() ;會(huì)報(bào)錯(cuò),會(huì)提示模糊的成員變量,因?yàn)閠iger和lion中都包含父類animal的op()操作。
此時(shí)內(nèi)存中的oneliger對(duì)象布局從低到高是下面這樣的:
1、animal的成員變量
2、繼承tiger的成員變量
//包括 op()
3、繼承l(wèi)ion的成員變量
/ /也包括op()
4、liger本身的成員變量
PS: 對(duì)象在內(nèi)存中的布局首先是如果有虛函數(shù)的話就是虛表,虛表就是指向一個(gè)函數(shù)指針數(shù)組的指針,然后就是成員變量,如果是普通繼承則首先是最根父類的成員變量,然后是次父類成員變量,依次而來(lái)最后是本身的成員變量[虛繼承相反],成員函數(shù)被編譯成全局函數(shù)不存儲(chǔ)在對(duì)象空間內(nèi),需要調(diào)用成員函數(shù)的時(shí)候,通過(guò)類名找到相應(yīng)的函數(shù),然后將對(duì)象的this指針傳給函數(shù):
比如這樣的代碼
CTest test;
test.print();
編譯器在內(nèi)部將轉(zhuǎn)換為:(偽代碼)
CTest test;
CTest_print( &test ); // CTest的print函數(shù)轉(zhuǎn)換為:CTest_print( CTest* const this);
所以這就和普通函數(shù)調(diào)用差別不大了
實(shí)際應(yīng)該是函數(shù)找到對(duì)象,即根據(jù)this指針
為了解決 上面多繼承的問(wèn)題,所以c++中提出了虛繼承的概念,虛繼承就是在子類中只保留一份父類的拷貝,拿上面的類子來(lái)說(shuō),就是“如果有一份父類的拷貝的話就用父類的拷貝,如果沒(méi)有就加入一份拷貝” :
class animal{
public :
void op()
{cout << "hello animal" ;}
};
class tiger : public virtual animal {
public :
void tg()
{cout << "this is tiger" ;}
};
class lion : public virtual animal {
public :
void lo()
{cout << "this is lion" ;}
};
class liger : public tiger, public lion {
public :
void lo()
{cout << "this is lion" ;}
};
int main()
{
class liger oneliger ;
liger.op() ;
}
此時(shí)liger對(duì)象在內(nèi)存中的布局就變成了:
4、animal的成員變量
3、繼承tiger的成員變量
//包括 op()
2、繼承l(wèi)ion的成員變量
//已經(jīng)包含一份拷貝,所以 已經(jīng)不包括op()
1、liger本身的成員變量
這樣內(nèi)存中就只有一份animal對(duì)象的拷貝,所以就不會(huì)存在模糊的問(wèn)題;
相關(guān)文章
distinct 多列問(wèn)題結(jié)合group by的解決方法
distinct 多列問(wèn)題 group by 解決2010-06-06解決SQL Server無(wú)法啟動(dòng)的小技巧
SQLServer無(wú)法正確啟動(dòng)是由于Executive服務(wù)無(wú)法登錄引起的,下面就教您一個(gè)處理SQL Server無(wú)法啟動(dòng)的方法,需要的朋友可以參考下2015-08-08SQLServer數(shù)據(jù)庫(kù)中開(kāi)啟CDC導(dǎo)致事務(wù)日志空間被占滿的原因
這篇文章主要介紹了SQLServer數(shù)據(jù)庫(kù)中開(kāi)啟CDC導(dǎo)致事務(wù)日志空間被占滿的原因分析和解決辦法(REPLICATION),需要的朋友可以參考下2017-04-04VS2015安裝之后加裝Sql server2014詳細(xì)步驟
這篇文章主要介紹了VS2015安裝之后加裝SQL SERVER2014詳細(xì)步驟,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12sql?server導(dǎo)入、導(dǎo)出數(shù)據(jù)庫(kù)詳細(xì)圖文教程
這篇文章主要給大家介紹了sql?server導(dǎo)入、導(dǎo)出數(shù)據(jù)庫(kù)的相關(guān)資料,數(shù)據(jù)的導(dǎo)入是指從其他數(shù)據(jù)源中把數(shù)據(jù)復(fù)制到SQL Server數(shù)據(jù)庫(kù)中,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10SQLServer EVENTDATA()函數(shù)來(lái)獲取DDL 觸發(fā)器信息
SQL Server 2005/2008中可以使用EVENTDATA函數(shù)來(lái)獲取DDL觸發(fā)器的上下文,從而在ROLLBACK之前截獲DDL信息。EVENTDATA返回XML字段,下面的例子顯示如何截獲Drop Table的DDL信息。2009-07-07解析SQL Server聚焦移除(Bookmark Lookup、RID Lookup、Key Lookup)
本文主要講解索引性能優(yōu)化,著重對(duì)Bookmark Lookup、RID Lookup、Key Lookup三者進(jìn)行移除的實(shí)現(xiàn)進(jìn)行解析,以此來(lái)提高查詢性能。希望對(duì)大家有所幫助2016-12-12