Bigthree

类成员涉及到指针的情况时:

class String
{
private:
    char * m_data;//m_data为指针
public:
    ...
};

存在三个成员函数(Big Three)的设计:拷贝构造函数,拷贝赋值函数和析构函数

class String
{
private:
    char * m_data;  //m_data为指针
public:
    String(const char* cstr);  //赋值函数
    String(const String& str);  //拷贝构造,接受的参数同为String类
    String& operator= (const String& str);//拷贝赋值
    ~String();     //析构函数
};

设计拷贝构造函数和拷贝赋值函数是为了防止出现浅复制的问题(浅复制会造成内存泄露)
拷贝构造函数定义:

inline String::String(const String&str)//拷贝构造,深拷贝
{
    m_data = new char[strlen(str.m_data)+1];//根据str中字符串的大小给调用此函数的String类分配内存空间。
    strcpy(m_data,str.m_data);//strcpy作用是复制字符串,返回值类型为char*。
                            // 此处将str中的字符串str.m_data复制到调用此函数的String类的m_data中。
}

在定义拷贝赋值函数时要考虑自我赋值这一情况。如果未考虑此情况,在执行到delete[] m_data;这一语句时,会使指针指向已经删除的对象。
拷贝赋值函数定义:

inline String& String::operator= (const String &str)
{
    if(this == &str)    //检测自我赋值
        return *this;
    delete[] m_data;
    m_data = new char(strlen(str.m_data)+1);
    strcpy(m_data,str.m_data);
    return *this;
}

设计析构函数用来释放类成员调用构造函数时使用new语句分配的内存(构造函数和赋值函数中使用new就一定要有析构函数)
构造函数:

inline String::String(const char* cstr)
{
    if(cstr)
    {
        m_data = new char[strlen(cstr)+1];  //构造函数参数不空时
        strcpy(m_data,cstr);
    }
    else    //构造函数参数为空
    {
        m_data = new char[1];
        *m_data = '\0';
    }
}

析构函数

inline String::~String()
{
    delete [] m_data;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值