动态绑定:父类析构函数不声明为虚析构函数的灾难。。。。

class Parent { public: Parent(){}; ~Parent(){}; }; class Child : public Parent { public: Child() { p = new int[10240000]; cout<<"constructor"; }; ~Child() { if(p) { delete [] p; cout<<"destructor"; } } int * p; }; void main() { Parent * p = new Child(); delete p; }

以上代码,执行结果是输出“constructor”没有输出“destructor”。会觉得很奇怪,明明调用了构造函数,却不调用析构函数。

实际上,在这里,当delete p时,编译器会自动找到p的类型(既Parent)的析构函数去执行,与我们期望的相差很远。

因此,要实现动态绑定,就一定要把父类的析构函数设为virtual的。这样,当调用Parent的析构函数时,根据虚指针的偏移,最终实现调用p所指的类型既Child类型的析构函数。

你可能感兴趣的:(delete,Class,Constructor,编译器,destructor)