C++为什么父类析构函数要定义为虚析构函数
这个问题主要是由于子类继承父类时,构造函数和析构函数的调用问题产生的结果:
第一点我们需要知道,子类在继承时构造函数是不能被继承的。但是,为了初始化从父类继承来的数据成员,系统需要调用其父类的构造方法。因此必定会调用父类的构造函数。
构造原则:
如果子类没有定义构造方法,则调用父类的无参数的构造方法。
如果子类定义了构造方法,不论是无参数还是带参数,在创建子类的对象的时候,首先执行父类无参数的构造方法,然后执行自己的构造方法。
在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数,则会调用父类的默认无参构造函数。
在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类自己提供了无参构造函数,则会调用父类自己的无参构造函数。
在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类只定义了自己的有参构造函数,则会出错(如果父类只有有参数的构造方法,则子类必须显示调用此带参构造方法)。
如果子类调用父类带参数的构造方法,需要用初始化父类成员对象的方式
总结一点就是,只要使用子类来定义一个对象,就必定会调用父类的构造函数或者默认构造函数。
就是有蛋必有鸡,可能这个会有异议;换句话说就是想有儿子必有爹,想要有儿子,就必须要先把父亲的东西安置好。这个没办法反驳吧。hh
可能会有人纠结上面六种方法,那么我们先看下上面的六种方法:
不用看子类如何,父类可以分为两类,仅仅就是子类写构造函数的区别:</