http://topic.csdn.net/t/20041125/14/3587677.html
http://topic.csdn.net/t/20041125/14/3587677.html
6 楼LionEagle(LionEagle)回复于 2002-06-20 09:00:06 得分 0
从实现上看,vbtl在构造函数调用后才建立,因而构造函数不可能成为虚函数
从实际含义上看,在调用构造函数时还不能确定对象的真实类型(因为子类会调父类的构造函数);而且构造函数的作用是提供初始化,在对象生命期只执行一次,不是对象的动态行为,也没有太大的必要成为虚函数
9 楼yyzzbb_yang(eric)回复于 2002-06-20 09:53:29 得分 0
首先你要明白:纯虚拟函数是用来提供函数接口的,虚拟函数是用来提供函数接口和默认的函数操作,非虚拟函数是用来提供函数操作的。而且你一定要记住不要在subclass中重新定义一个非虚拟函数。我想你了解了他们三者的区别,应该知道为什么了吧?
构造函数是用来构造本对象的,它肯定不能被别人重新定义,因为在别的类中是不可以访问private member的(除了friend class和function);而在继承体系中,base class的析构函数一般声明成virtual function,因为subclass要重新定义它用来摧毁object。Top
如果有这样两个类:
class A {
public:
A() { a = "A"; f(); }
virtual ~A() {}
virtual f() { cout << a << endl; }
private:
char* a;
};
class B : public A {
public:
B() { b = "B"; }
~B() {}
f() { cout << b << endl; }
private:
char* b;
};
构造函数调用顺序是先调用基类构造函数,即: A(), B()
在A()中调用f(),如果按虚函数调用规则,它应该调用B::f(),但此时B还没构造(B()还没有执行),执行B::f()必然是一个错误。所以在构造函数内部执行时,对象还没有完全构造好,不能按虚函数方式进行调用,构造函数本身不能为虚函数也是相同的原因了。Top
构造函数和析构函数是由编译器和程序员共同完成,而类的其他成员函数是由程序员完成,所以编译器会对构造函数和析构函数给予特殊的照顾,比如它们不能有返回值,构造函数不可以是虚函数等等。
析构函数可以是虚函数,而且有的时候是必须的,基类指针指向派生类,用基类指针delete时,如果不定义成虚函数,派生类中派生的那部分无法析构。
构造函数不可以是虚函数,因为编译通不过。假如开发编译器的人让它编译通过,有意思的事情就会发生(HAHA),程序会说,我的构造函数在哪?原因是构造函数的地址在虚拟表中,而类的pvtable此时没有被初始化,pvtable可能是任何东西(pvtable初始化在构造函数中完成)