继承和动态内存分配

来源:互联网 发布:权力的48条法则 知乎 编辑:程序博客网 时间:2024/05/22 01:33

1:首先,假设基类使用了动态内存分配,并定义了显式析构函数,复制构造函数和赋值运算符,那么,从该基类中派生出来的派生类,就不需要使用new,也未包含其他不常用的,需要特殊处理的设计特性。这是因为,派生类的默认构造函数总要进行一些操作:执行自身的代码后调用基类析构函数,因此,默认析构函数是合适的。

关于赋值构造函数,默认的复制构造函数执行成员复制,这对于动态内存分配来说似乎不合适的,但是,对于派生类是合适的,因为,成员复制将根据数据类型采用相应的复制方式,将long复制到long是按值赋值,但复制类成员或继承的类组件时,则是使用该类的复制构造函数完成的。因此,派生类的默认复制构造函数使用显式的基类复制构造函数来复制派生类对象中基类部分。因此,默认复制构造函数对于新的派生类成员是合适的,对于从基类中继承过来的对象也是合适的。

再看赋值运算符,类的默认赋值运算符将自动使用基类的赋值运算符来对基类组建进行赋值。

2:当派生类使用了new,则必须为派生类定义显式析构函数,复制构造函数和赋值运算符。

派生类析构函数自动调用基类的析构函数,因此,派生类的析构函数式对派生类的构造函数执行的工作进行清理。因此,派生类的析构函数必须释放派生类中new出来的内存。

派生类的复制构造函数只能访问派生类的数据,因此,它必须调用基类的复制构造函数来处理共享的基类数据。、

hasDMA::baseDMA(const hasDMA & hs):baseDMA(hs)

{...}

需要注意的是,成员初始化列表将一个hasDMA引用传递给baseDMA构造函数。没有参数类型为hasDNA引用的baseDMA构造函数,也不需要这样的构造函数,因为复制构造函数baseDMA有一个baseDMA引用参数,而基类引用可以指向派生类行。因此,baseDMA复制构造函数将使用hasDMA参数的baseMDA部分来构造新对象的baseDMA部分。

0 0
原创粉丝点击