《effective C++》 条款09.
在这个条款中,只需要弄明白一个问题。
问题:如果在构造和析构函数中调用了virtual函数,结果会是这么样的?
如果在base类中的构造函数和析构函数中调用了virtual函数,则base类中析构函数和析构函数所执行的virtual函数是base类中的virtual函数,而不是derived对象中的virtual函数。因为在创建子类对象前,是先调用base类的构造函数,此时子类还没有创建成功,即子类构造函数中的virtual函数还不存在,所以此时base类的构造函数调用的virtual函数只能够是base来的virtual函数。在执行子类对象的析构函数后,子类中的virtual函数也不再存在了,所以当执行base类的析构函数时,所执行的virtual函数只能够是base类的virtual函数。
如果子类中的构造函数和析构函数也调用了virtual函数,则子类中的析构函数和析构函数所执行的virtual函数是子类中的virtual函数。
下面是UC2014年实习生笔试题
class A
{
public:
A(){fun();}
virtual ~A(){fun();}
virtual void fun (){cout<<"Function of A"<
fun();
return 0;
}
Function of A//执行基类构造函数,base函数构造函数执行base类中的virtual函数
Construction of B//执行子类构造函数
Function of B//执行a->fun() ,执行的是子类中的virtual函数
Destruction of B//执行子类的析构函数
Function of A//执行基类的析构函数,基类的析构函数执行base类中的virtual函数