C++初探_继承与动态内容分配

代码:

#include <iostream>
using namespace std;
class baseDMA {
private:
    char* label;
    int rating;
public:
    baseDMA(char* l = nullptr, int r = 0);
    baseDMA(baseDMA& rs) { // 复制构造函数
        label = new char[strlen(rs.label) + 1];
        strcpy(label, rs.label);
        rating = rs.rating;
    }
    virtual ~baseDMA() {
        delete[] label;
    }; //虚析构函数。当存在派生类对象初始化基类的指针或引用,需要虚析构函数保证对象被正确释放。
    baseDMA& operator=(baseDMA& rs) { // 重载赋值运算符函数
        if (this == &rs) // 若是给自己赋值就直接返回
            return *this;
        delete[] label; // 先清空之前保存的内容
        label = new char[strlen(rs.label) + 1]; 
        strcpy(label, rs.label);
        rating = rs.rating;
        return *this; //返回this指针的内容
    }
};
class hasDMA :public baseDMA {
private:
    char* style;
public:
    hasDMA(hasDMA& hs) :baseDMA(hs) {
        style = new char[strlen(hs.style) + 1];
        strcpy(style, hs.style);
    }
    hasDMA& operator=(hasDMA& hs) {
        if (this == &hs) // 若是给自己赋值就直接返回
            return *this;
        baseDMA::operator=(hs); // 调用基类赋值运算符重载函数
        delete[] style; // 先清空之前保存的内容
        style = new char[strlen(hs.style) + 1];
        strcpy(style, hs.style);
        return *this;
    }
    ~hasDMA() {
        delete[] style;
    }
};

分析:

若派生类使用了动态内存分配,那么就必须为派生类定义显示的:析构函数、复制构造函数、赋值运算符重载函数。

并且,派生类的析构函数、复制构造函数、赋值运算符重载函数都将使用相应的基类的析构函数、复制构造函数、赋值运算符重载函数来处理基类的元素。

(1)析构函数:派生类析构函数会自动调用基类的析构函数。

(2)复制构造函数:应在成员初始化列表调用基类的复制构造函数来处理基类的成员。这是合理的,因为基类的引用可以指向派生类的对象,反过来则不允许(单向性)。

(3)赋值运算符重载函数:应显示地使用作用域运算符调用基类的赋值运算符重载函数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值