您好,登錄后才能下訂單哦!
如何理解C++中的繼承與虛繼承,針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
class test1 { public: test1(int i) :num1(i) {} private: int num1; }; class test2 : public test1 { public: test2(int i,int j) : test1(i), num2(j) { } private: int num2; }; void main() { test2 t2(1,2); }
(test2內(nèi)存結(jié)構(gòu))查看內(nèi)存發(fā)現(xiàn)父類在子類的上面
在原有的代碼基礎(chǔ)上增加了test3類
test3類繼承了 test2和test1
class test1 { public: test1(int i) :num1(i) {} private: int num1; }; class test2 { public: test2(int i) : num2(i) { } private: int num2; }; class test3 :public test2 ,public test1 { public: test3(int i, int j,int k) :test1(i), test2(j),num3(k) {} private: int num3; }; void main() { test3 t3(1, 2, 3); }
(test3內(nèi)存地址 ) 依舊是父類在子類上
但是現(xiàn)在有兩個父類為什么test2在test1上?
這和我們的繼承順序有關(guān) 我們先繼承了test2又繼承了test1 更換內(nèi)存繼承順序 內(nèi)存的情況也會有所變化
class test1 { public: test1(int i) :num1(i) {} private: int num1; }; class test2: virtual public test1 { public: test2(int i,int j) :test1(i), num2(j) { } private: int num2; }; void main() { test2 t2(1, 2); }
(t2的內(nèi)存) 我們發(fā)現(xiàn)虛繼承以后父類成員數(shù)據(jù)在子類成員數(shù)據(jù)下面了 首地址處莫名其妙多了四字節(jié)
這四字節(jié)就是我們的虛基類表的地址
跟隨虛繼承表 其中存儲了本類距離父類對象的差值 通過差值能夠找到父類對象
我們再看這個內(nèi)存0x0082fbd8是t2的首地址 0x0082fbe0是父類的位置
0x0082fbd8 - 0x0082fbe0 == 8
就是本類距離父類對象的差值
class test1 { public: test1(int i) :num1(i) {} private: int num1; }; class test2: virtual public test1 { public: test2(int i,int j) :test1(i), num2(j) { } private: int num2; }; class test3 :virtual public test1 { public: test3(int i, int j) :test1(i), num3(j){} private: int num3; }; class test4 :public test2, public test3 { public: test4(int i, int j, int k) :test1(i),test2(i,j), test3(i,j),num4(k) { } private: int num4; }; void main() { test4 t4(1, 2,3); }
test4的內(nèi)存 我們看到 t2和t3都有自己的虛基類表地址 記錄了自己和父類的偏移
兩個虛基類表的內(nèi)容
現(xiàn)在我們計算一下 到爺爺類的差值是否正確
0x00FAFD50 - 0x00fafd3c == 14
0x00FAFD50 - 0x00fafd44 == C
關(guān)于如何理解C++中的繼承與虛繼承問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。