浅谈C++的virtual 动态绑定。
生活随笔
收集整理的這篇文章主要介紹了
浅谈C++的virtual 动态绑定。
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
我們知道C++里 virtual函數可以用來實現多態。繼承類可以實現自己的功能來覆蓋基類。比如下面這段代碼
#include<iostream> #include<string> using namespace std; class BaseA{ public:BaseA(string n):name(n){}string getName() const;virtual void showMyName() const;string name; };class DerivedA:public BaseA{ public:DerivedA(string n):BaseA(n){}string getName() const;virtual void showMyName() const; };string BaseA::getName() const {cout<<"base static"<<endl;return name; }void BaseA::showMyName() const {cout<<"base:"<<name<<endl; }string DerivedA::getName() const {cout<<"derived static"<<endl;return name; }void DerivedA::showMyName() const {cout<<"derived:"<<name<<endl; }int main() {DerivedA * derivedA = new DerivedA(string("abcd"));BaseA baseA = * derivedA; //會調用copy constructor函數 baseA.showMyName();baseA.getName();BaseA * pBaseA = derivedA;pBaseA->showMyName();pBaseA->getName();return 0; }這段代碼的輸出:
base:abcd
base static
derived:abcd
base static
?
我們來解讀一下:
BaseA baseA = * derivedA;這里其實是構造了一個BaseA類,也就是構造了一個基類,雖然是右值是繼承類。
但這里會調用BaseA的default copy assignment函數,構造一個BaseA的實例。
derivedA會被截斷。
那么當然了
baseA.showMyName();baseA.getName();
這倆行會調用BaseA的函數。
我們再看一下下面這行 BaseA * pBaseA = derivedA;
這里聲明了一個BaseA的指針 然后把指針指向派生類 DerivedA的一個實例。 再看下面的代碼
pBaseA->showMyName(); pBaseA->getName();
showMyName我們定義成了Virtual,也就是在內存里會有個函數指針,指向不同的實現。
對于derivedA來說,這個函數的指針當然是指向DerivedA的showMyName。
而pBaseA拿到的是derivedA的指針,那么當然調用的函數也會是DerivedA的實現函數。
這個就是所謂的動態綁定。
下面再看getName,相對于動態綁定函數,這是個靜態函數,什么事靜態函數呢,
就是這個函數會根據對象的靜態類型來調用。比如pBaseA的靜態類型是BaseA,
那么pBaseA所調用的就是BaseA的getName。
?
??
轉載于:https://www.cnblogs.com/hojor/p/4424483.html
總結
以上是生活随笔為你收集整理的浅谈C++的virtual 动态绑定。的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java 常见数据类型
- 下一篇: HLG2040二叉树遍历已知前中,求后