13.7.1 第一种情况:派生类不使用 new

13.7.1 第一种情况:派生类不使用 new

假设基类为下述使用了动态内存分配的类:
// Base Class Using DMA
class baseDMA

private:
char * label:
int rating:

public:
baseDMA (const char * 1 = "null", int r = 0):
baseDMA ( const baseDMA & rs):
virtual ~baseDMA():
baseDMA & operator= (const baseDMA & rs);

-

声明中包含了构造函数使用new时需要的特殊方法:析构函数、复制构造函数和重载赋值操作符。
现在,从baseDMA派生出lackDMA类,而后者不使用new或者包含其他一些不常用的、需要特殊处
理的设计特性:
// derived class without DMA
class lacksDMA: public baseDMA

private:
char color [40]:
public:

1:
是否需要为lackDMA类定义显式析构函数、复制构造函数和赋值操作符呢?不需要。
首先,来有是否需要析构函数。如果没有定义析构函数,编译器将定义一个不执行任何操作的默认构
造函数。实际上,派生类的默认构造函数总是要进行一些操作:执行自身的代码后调用基类析构函数。因
为我们假设lackDMA成员不需执行任何特殊操作,所以默认析构函数是合适的。
接着米看复制构造函数。第12章介绍过,默认复制构造函数执行成员复制,这对于动态内存分配来说
是不合适的,但对J新的lacksDMA成员来说是合适的。因此只需考虑继承的baseDMA对象。要知道,成
员复制将根据数据类型采用相应的复制方式,因此,将long复制到long 中是通过使用常规赋值完成的;
但复制类成员或继承的类组件时,则是使用该类的复制构造函数完成的。所以,lacksDMA 类的默认复制
构造函数使用显式baseDMA复制构造函数来复制lacksDMA对象的baseDMA部分。因此,默认复制构造
函数对于新的lacksDMA成员来说是合适的,同时对于继承的baseDMA对象来说也是合适的。
对于赋值来说,也是如此,类的默认赋值操作符将自动使用基类的赋值操作符来对基类组件进行赋值。
因此,默认赋值操作符也是合适的。
派生类对象的这些属性也适用于本身是对象的类成员。例如,第10章介绍过,实现Stock类时,可以
使用string对象而不是char数组来存储公司名称。标准string类和本书前面创建的String类一样,也采用
动态内存分配。现在,读者知道了为何这不会引发问题。Stock的默认复制构造函数将使用string的复制构
造函数来复制对象的company 成员;Stock的默认赋值操作符将使用string的赋值操作符给对象的company
成员赋值:而Stock的析构函数(默认或其他析构函数)将自动调用string的析构函数。

13.7.2 第二种情况:派生类使用 new

假设派生类使用了new:
// derived class with DMA
class hasDMA: public baseDMA

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值