C++ 继承和动态内存分配

本文探讨了当基类使用动态内存分配并重新定义赋值及复制构造函数时,如何影响派生类的实现。文章详细分析了两种情形:派生类是否使用new操作符。介绍了派生类在不同情况下定义析构函数、复制构造函数和赋值运算符的必要性和方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

例如,如果基类使用动态内存分配,并重新定义赋值和复制构造函数,这将怎样影响派生类的实现?取决于派生类的属性。有以下两种情况:

第一种:派生类不使用new

此时不用为drived类定义显式析构函数,复制构造函数和赋值运算符。

此时的drived类的默认赋值构造函数使用显式base类的复制构造函数来复制drived对象的base部分。

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

 

第二种:派生类使用new

 

在这种情况下必须为派生类定义显式析构函数,复制构造函数和赋值运算符。

派生类析构函数自动调用基类的析构函数,故其自身的职责是对派生类构造函数执行工作的进行清理。

例如下面使用new运算符的复制构造函数,赋值构造函数:

对于构造函数,这是通过在初始化成员列表中调用基类的复制构造函数来完成的;如果不这样做将自动调用基类的默认构造函数。

对于赋值运算符,这是通过作用域解析运算符显式的调用基类的赋值运算符来完成的。

 

 

因为输出函数为友元函数,不是成员函数,所以不能用作用域解析运算符来指出要使用哪个函数。

输出时也应进行强类型转换,以便匹配原型时能够选择正确的函数:

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值