编写高质量代码——重载operator=的标准三步走

发布时间:2025-05-11 03:13

编写单元测试提高代码质量 #生活知识# #生活经验# #编程#

最新推荐文章于 2025-03-06 21:04:38 发布

SmartSmall 于 2014-06-03 23:12:16 发布

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

CString& CString::operator=(const CString& str){

  if(this == &str)       //1.自赋值检查

      return *this;       

  if(pChar!=NULL)       //2.释放原有空间

    delete[]  pCahr;

  pChar = new char[strlen(str.pChar)+1]; // 2.申请新空间

  strcpy(pChar, str.pChar);  //2.数据复制    (不要忘记对基类的赋值)

  return *this;   //3.返回对象的引用

}

█不要让编译器帮你重载赋值运算符(浅拷贝、POD对象、堆内存)

█一定要检查自赋值

1)效率,特别是具有内存分配操作。

2)如果目标对象pChar不为NULL,会将目标对象pChar指向的内存首先释放。又因为自赋值,原对象pChar与目标对象pChar指向通过目标对象 pChar 释放掉的空内存空间。后续操作的危险性不言而喻。

【自赋值操作】

█赋值运算符重载需返回 *this 的应用(链式赋值【内置数据类型支持】)

例如:

class CString{ };

CString str1("Hello C++");

CString str2, str3;

str3 = str2 =str1;

相当于:str3.operator=(str2.operator=(str1));//赋值运算符具有右结合性

返回值应为“引用”:

1)效率(避免返回对象构造、析构的过程)

2)存在括号改变赋值的顺序:

class CString{ };

CString str1("Hello C++");

CString str2, str3;

(str3 = str2) =str1; //如果非引用,将返回临时对象,临时对象不允许调用成员函数

█赋值运算符重载函数不能重载  //虽然没有显式地为派生类声明赋值运算符重载函数,但是不要忘记编译器悄悄做的事!基类 operator= 被隐藏。

█派生类中 operator= 重载函数应为对象中的所有数据成员进行一一赋值,最重要的是:基类部分最简单的方式,即直接调用基类的 operator=

网址:编写高质量代码——重载operator=的标准三步走 https://www.yuejiaxmz.com/news/view/953166

相关内容

C++ operator关键字(重载操作符)
编写高质量和可维护的代码方法
OpenAI全新AI助理产品“Operator”即将发布,开启智能时代新篇章
OpenAI推出新型AI代理Operator,重新定义自动化任务执行方式
编写高效代码:如何通过代码优化提升程序性能
如何编写低碳环保的 Android 代码
新AI助理来袭!OpenAI的Operator将如何改变你的生活?
为什么要代码重构?如何重构?常见重构技巧,值得收藏!
OpenAI即将推出“Operator”智能体:自动化任务的新纪元
如何用代码完成重复工作,提升生活质量

随便看看