c++虛函數(shù)與虛函數(shù)表原理
1.什么是虛函數(shù)?
用virtual
修飾的成員函數(shù)叫虛函數(shù)
小知識: 沒有虛構(gòu)造函數(shù) 不寫虛函數(shù),沒有默認(rèn)的虛函數(shù)
普通函數(shù)不影響類的內(nèi)存:
class MM { public: void print() { cout << "普通函數(shù)"<< endl; //普通函數(shù)不影響類的內(nèi)存<--->普通函數(shù)存在另一段內(nèi)存中 } protected: }; void testVirtual() { //C語言不允許存在空的結(jié)構(gòu)體 cout << sizeof(MM) << endl;/*(沒有數(shù)據(jù)成員的)空的類或者結(jié)構(gòu)體 占用1字節(jié) 用1字節(jié)標(biāo)識當(dāng) 前內(nèi)存為結(jié)構(gòu)體內(nèi)存*/ } int main() { testVirtual(); return 0; } /*輸出*/ /* 1 */
2.虛函數(shù)會影響類的內(nèi)存
增加一個指針的內(nèi)存,32位操作系統(tǒng)多4個字節(jié) ,64位操作系統(tǒng)多8個字節(jié)
#include <iostream> using namespace std; class MM { public: virtual void print1() { cout << "虛函數(shù)1"<< endl; } /*virtual void print2() { cout << "虛函數(shù)2" << endl; } 無論多少個虛函數(shù),增加的字節(jié)就是一個指針的字節(jié)--->多了一個虛函數(shù),還是4個字節(jié)*/ protected: }; void testVirtual() { cout << sizeof(MM) << endl; } int main() { testVirtual(); return 0; } /*輸出*/ /* 4 */
小知識:一旦有了數(shù)據(jù),標(biāo)識位就不需要存在了
class A { int num; //輸出4而不是5 (4+1) }; class B { //用1字節(jié)標(biāo)識當(dāng)前內(nèi)存為結(jié)構(gòu)體內(nèi)存 }; void testVirtual() { cout << sizeof(A) << endl; cout << sizeof(B) << endl; } int main() { testVirtual(); return 0; } /*輸出*/ /*4 1*/
3.了解虛函數(shù)表--->通過虛函數(shù)表的指針去訪問數(shù)據(jù)
就是一個指針存儲所有虛函數(shù)的首地址(虛函數(shù)函數(shù)名)<--->函數(shù)指針
只有指針可以操作一段內(nèi)存(4字節(jié))
/*無論多少個虛函數(shù),增加的字節(jié)就是一個指針的字節(jié)*/
所有的虛函數(shù)其實是 用一個函數(shù)指針去存儲的 ,把 這個函數(shù)指針指向的這一段內(nèi)存 稱為虛函數(shù)表
#include <iostream> using namespace std; class MM { public: virtual void print1() { cout << "虛函數(shù)1"<< endl; } virtual void print2() { cout << "虛函數(shù)2"<< endl; } protected: }; void testVirtual() { //虛函數(shù)表 MM mm; //構(gòu)建一個對象 int** vptr = (int** )&mm; //定義一個二級指針&對象的地址 強轉(zhuǎn)類型 typedef void(*PF)(); //函數(shù)指針定義別名 PF func = (PF)vptr[0][0]; //把地址轉(zhuǎn)為函數(shù)指針,訪問第一個函數(shù)指針的地址 func(); //通過虛函數(shù)表的函數(shù)指針調(diào)用第一個虛函數(shù) func = (PF)vptr[0][1]; func(); //調(diào)用第二個虛函數(shù) } int main() { testVirtual(); return 0; } /*輸出*/ /*虛函數(shù)1 虛函數(shù)2*/
4.虛函數(shù)聲明
虛函數(shù)可以在類中聲明,在類外實現(xiàn),不再需要virtual
修飾詞,只要類名限定就可以了
class MM { public: virtual void print3(); protected: }; void MM::print3() { cout << "虛函數(shù)3" << endl; } int main() { MM mm; mm.print3(); return 0; } /*輸出*/ /*虛函數(shù)3*/
到此這篇關(guān)于c++虛函數(shù)與虛函數(shù)表原理的文章就介紹到這了,更多相關(guān)c++虛函數(shù)與虛函數(shù)表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Qt數(shù)據(jù)庫應(yīng)用之實現(xiàn)通用數(shù)據(jù)庫采集
這篇文章主要為大家介紹了Qt中是如何實現(xiàn)通用數(shù)據(jù)庫采集的,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Qt有一定幫助,感興趣的小伙伴可以了解一下2022-03-03C語言實現(xiàn)學(xué)生選課系統(tǒng)完整版
這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)學(xué)生選課系統(tǒng)的完整版,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-02-02一起來學(xué)習(xí)C語言的程序環(huán)境與預(yù)處理
這篇文章主要為大家詳細(xì)介紹了C語言程序環(huán)境與預(yù)處理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03C++ 操作系統(tǒng)內(nèi)存分配算法的實現(xiàn)詳解
本文主要介紹了在動態(tài)分區(qū)管理方式下采用不同的分配算法實現(xiàn)主存分配和實現(xiàn)主存回收,旨在幫助學(xué)生理解在動態(tài)分區(qū)管理方式下應(yīng)怎樣實現(xiàn)主存空間的分配和回收。感興趣的可以了解一下2021-11-11