关于二者执行的顺序,正常来说,是:构造父类-构造子类-析构子类-析构父类 (栈的顺序)
比如 class F{}; class S : public F{}; S* s = new S(); delete s; 就会按照上面的顺序执行。
但是,class F{}; class S : public F{}; F* s = new S(); delete s; 也是构造父类然后构造子类,但是只会调用父类的析构函数(前提是析构函数是非虚函数)
因此,如果一个类可能会派生子类,那么就把析构函数定义成虚函数。上面的例子在虚析构函数的情况下执行顺序是:构造父类-构造子类-析构子类-析构父类