以上代码,执行结果是输出“constructor”没有输出“destructor”。会觉得很奇怪,明明调用了构造函数,却不调用析构函数。
实际上,在这里,当delete p时,编译器会自动找到p的类型(既Parent)的析构函数去执行,与我们期望的相差很远。
因此,要实现动态绑定,就一定要把父类的析构函数设为virtual的。这样,当调用Parent的析构函数时,根据虚指针的偏移,最终实现调用p所指的类型既Child类型的析构函数。
以上代码,执行结果是输出“constructor”没有输出“destructor”。会觉得很奇怪,明明调用了构造函数,却不调用析构函数。
实际上,在这里,当delete p时,编译器会自动找到p的类型(既Parent)的析构函数去执行,与我们期望的相差很远。
因此,要实现动态绑定,就一定要把父类的析构函数设为virtual的。这样,当调用Parent的析构函数时,根据虚指针的偏移,最终实现调用p所指的类型既Child类型的析构函数。