赋值运算符重载中返回值是否为引用的区别

在一些资料和书籍中,都告诉我们如果要实现自定义类的连续赋值重载,那么就需要将赋值重载的返回值定义为引用。

但直接返回实例依然可以实现连续赋值的功能。

class MYString
{
private:
    char* m_pdata;
public:
    MYString(char *pData=nullptr);
    MYString(const MYString&str);
    MYString operator+(const MYString& a);
    MYString operator=(const MYString& a);
    char* getdata();
    ~MYString();
};
MYString MYString::operator=(const MYString& a)
{
    if(this==&a)
    {
        return *this;
    }
    delete []m_pdata;
    this->m_pdata = nullptr;

    this->m_pdata = new char[strlen(a.m_pdata) + 1];
    strcpy(this->m_pdata,a.m_pdata);
    return *this;
}

我将赋值重载的返回直接设置为了MYString实例,然后在main函数中进行验证:

 int main(int argc, char* argv[])
 {
    MYString a("abc");
    MYString b("def");
    MYString c("ghi");
    MYString d("");
    printf("a.mdata=%s,b.m_data=%s,c.m_data=%s\n",a.getdata(),b.getdata(),c.getdata());
    // d=a+b+c;
    d=b=c=a;
    printf("the data is %s\n",d.getdata());
     return 0;
 }

程序的输出如下:

这意味着程序并没有出现像一些资料中提示的不使用引用就无法通过编译的情况,能够正常的使用。那么是否使用引用作为赋值重载的返回值真正的区别时什么呢?

在构造函数和析构函数中打印一些输出,以检验两者的区别,同样的主函数调用方法:

int main(int argc, char* argv[])
 {
    MYString a("abc");
    MYString b("def");
    MYString c("ghi");
    MYString d("");
    printf("a.mdata=%s,b.m_data=%s,c.m_data=%s\n",a.getdata(),b.getdata(),c.getdata());
    // d=a+b+c;
    d=b=c=a;
    printf("the data is %s\n",d.getdata());
     return 0;
 }

当使用对象作为返回时,程序的输出为:

当使用引用作为返回值时,程序的输出为:

也就是说,如果使用引用作为返回值,则每次赋值操作都不必在调用一次拷贝构造函数和析构函数,可以避免一些无端的开销,这才是需要使用引用作为返回值的真正原因。

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值