c++ 結構函數中調用虛函數的完成辦法。本站提示廣大學習愛好者:(c++ 結構函數中調用虛函數的完成辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是c++ 結構函數中調用虛函數的完成辦法正文
我們知道:C++中的多態使得可以依據對象的真實類型(靜態類型)調用不同的虛函數。這種調用都是對象曾經構建完成的狀況。那假如在結構函數中調用虛函數,會怎樣樣呢?
有這麼一段代碼:
class A { public: A ():m_iVal(0){test();} virtual void func() { std::cout<<m_iVal<<‘ ';} void test(){func();} public: int m_iVal; }; class B : public A { public: B(){test();}; virtual void func() { ++m_iVal; std::cout<<m_iVal<<‘ '; } }; int main(int argc ,char* argv[]) { A*p = new B; p->test(); return 0; }
輸入: 0 1 2
也就是說,在結構函數中調用虛函數,調用的是正在結構的類中的虛函數,而不是子類的虛函數。
理一下順序。new了一個B對象,首先要調用基類結構函數,也就是A類的結構函數。調用test(),再調用虛函數func(),這時分用的是基類版本。之後再調用子類B的結構函數,這時調用的是子類虛函數func()。至於最後一次調用func(),依據多態,調用的是真實虛函數。
以上就是為大家帶來的c++ 結構函數中調用虛函數的完成辦法全部內容了,希望大家多多支持~