在构造函数中调用虚函数,并不会产生多态的效果,就跟普通函数一样。
c++ primer 第四版中497页15.4.5构造函数和析构中的虚函数讲到,如果在构造函数或析构函数中调用虚函数,则运行的是为构造函数或析构函数自身类型定义的版本。另外,必须通过基类类型的引用或指针进行函数调用才会发生多态。
相关帖子:http://bbs.csdn.net/topics/390537893
//示例1 #include <iostream> using namespace std; class A { private: int m_a; public: A(int a): m_a(a) {show();} virtual ~A() {}; virtual void show() const {cout << "show a: " << m_a << endl;} virtual void disp() const {cout << "disp a: " << m_a << endl;} }; class B: public A { private: int m_b; public: B(int a, int b): m_b(b), A(a) {} void show() const {cout << "show b: " << m_b << endl;} void disp() const {cout << "disp b: " << m_b << endl;} }; int main() { A* pob3 = new B(100, 200); pob3->disp(); delete pob3; return 0; }
//示例1运行结果 show a: 100 disp b: 200 请按任意键继续. . .
//示例2 #include <tchar.h> #include <iostream> using namespace std; class A { public: A() { cout << "A构造函数"; Test(); } ~A() { cout << "A析构函数"; cout << "A::Test()" << endl; } virtual void Test() { cout << "A::Test()" << endl; } }; class B :public A { public: B() { cout << "B构造函数"; Test(); } ~B() { cout << "B析构函数"; Test(); } virtual void Test() { cout << "B::Test()" << endl; } }; int _tmain(int argc, _TCHAR* argv[]) { A* pA = new B(); cout << "动态调用:"; pA->Test(); delete pA; return 0; }
//示例2运行结果 A构造函数A::Test() B构造函数B::Test() 动态调用:B::Test() A析构函数A::Test() 请按任意键继续. . .
//http://www.cnblogs.com/vcpp123/p/5795421.html
//转载请注明出处 //http://www.cnblogs.com/vcpp123/p/5795421.html
关键词:C++,构造函数,虚函数,多态,重载