C++——多态实现原理分析
生活随笔
收集整理的這篇文章主要介紹了
C++——多态实现原理分析
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
前言
虛函數執行速度要稍慢一些。為了實現多態性,每一個派生類中均要保存相應虛函數的入口地址表,函數的調用機制也是間接實現。所以多態性總是要付出一定代價,但通用性是一個更高的目標。
實驗環境
Windows10 企業版
Visual Studio2017 15.8.1
引入虛函數后內存大小變化
沒有虛函數時類占用內存大小
#include<iostream> using namespace std;class Base { public:Base(){cout << "Create Base" << endl;}~Base(){cout << "Free Base" << endl;} public:void Show(){cout << "This is Base Show()" << endl;} private:int x; };void main() {cout << sizeof(Base) << endl;Base b; } View Code占用內存為4字節。在x86 模式下,整形變量大小為4字節
有虛函數時類占用內存大小
#include<iostream> using namespace std;class Base { public:Base(){cout << "Create Base" << endl;}~Base(){cout << "Free Base" << endl;} public:virtual void Show(){cout << "This is Base Show()" << endl;} private:int x; };void main() {cout << sizeof(Base) << endl;Base b; } View Code占用內存為8字節。在x86 模式下,整形變量大小為4字節。剩下4字節是虛函數表指針,指針變量在x86下占內存大小4字節。
代碼中只定義了一個虛函數,定義多個虛函數,類的大小還是8。虛函數表的指針指向的是虛函數表的入口地址
虛函數表
1 #include<iostream> 2 using namespace std; 3 4 class Base 5 { 6 public: 7 Base() 8 { 9 cout << "Create Base" << endl; 10 } 11 ~Base() 12 { 13 cout << "Free Base" << endl; 14 } 15 public: 16 virtual void Show() 17 { 18 cout << "This is Base Show()" << endl; 19 } 20 virtual void Print() 21 { 22 cout << "This is Base Print()" << endl; 23 } 24 void Fun() 25 { 26 cout << "This is Base Fun()" << endl; 27 } 28 private: 29 int x; 30 }; 31 32 class D :public Base 33 { 34 public: 35 D() 36 {} 37 ~D() 38 {} 39 public: 40 void Show() 41 { 42 cout << "This is D Show()" << endl; 43 } 44 void Fun() 45 { 46 cout << "This is D Fun()" << endl; 47 } 48 virtual void List() 49 { 50 cout << "This is D List()" << endl; 51 } 52 private: 53 int y; 54 }; 55 56 void main() 57 { 58 D d; 59 } View Code虛函數表前后變化
虛函數表在構造父類的時候會記錄所有父類的虛函數
這里面少顯示了子類的List虛方法,少顯示是編譯器的問題。但是你不能通過父類指針訪問子類List()方法,因為List超出了父類范圍。
子類構造完成后,子類重寫了父類的虛函數,虛函數表中的虛函。數就變成了子類的。貍貓混太子,偷梁換柱的意思
?
轉載于:https://www.cnblogs.com/kelamoyujuzhen/p/9551717.html
總結
以上是生活随笔為你收集整理的C++——多态实现原理分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用Go语言+Protobuf协议完成一
- 下一篇: SpringData 简单的条件查询