拷贝构造函数和赋值构造函数

class CMyString
{
public:
 CMyString(char* pData = NULL);
 CMyString(const CMyString& str);
 ~CMyString(void);
 CMyString& operator = (const CMyString& str);
private:
 char* m_pData;
};

//赋值构造函数
CMyString& CMyString::operator = (const CMyString& str)
{
 if(this != &str)
 {
  //释放实例自身的内存,否则出现内存泄露
  /*if(m_pData != NULL)
  {
  delete[] m_pData;
  m_pData = NULL;
  }

  //新分配内存,将str的m_pData内存拷贝到m_pData中
  m_pData = new char[strlen(str.m_pData) + 1];
  strcpy(m_pData, str.m_pData);*/

  //在这个函数中,我们定义一个临时实例strTemp,并把strTemp的m_pData指向当前实例(*this)的m_pData。
  //由于strTemp是个局部变量,但程序员运行到if的外面是也就出了的该变量的域,就会自动调用strTemp的析构函数,
  //就会把strTemp.m_pData所指向的内存释放掉。由于strTemp.m_pData指向的内存就是当前实例之前m_pData的内存。
  //这就相当于自动调用析构函数释放当前实例的内存。如果新增加指针成员变量,
  //我们只需要在析构函数里正确地释放,而不需要对赋值运算符函数做任何修改。
  CMyString tempStr(str);
  char* temp = tempStr.m_pData;
  tempStr.m_pData = m_pData;
  m_pData = temp;
 }
 return *this;
}

//拷贝构造函数
CMyString::CMyString(const CMyString& str)
{
 m_pData = new char[strlen(str.m_pData) +1];
 strcpy(m_pData, str.m_pData);
 //memcpy(m_pData, str.m_pData, strlen(str.m_pData));
}

CMyString::~CMyString(void)
{
 if(m_pData != NULL)
 {
  delete[] m_pData;
  m_pData = NULL;
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值