令operator=返回一个reference to *this

1.我们先看一个例子

int x,y,z;
x = y = z =15;

  上述连锁赋值表达式被解析为:

x = (y = (z = 15));

  这里15先被赋值给z,然后其结果再被赋值给y,最后赋值给x。

2.如何实现“连锁赋值”
  为了实现“连锁赋值”,赋值操作符必须返回一个reference指向操作符的左侧实参。这是我们为classes实现赋值操作符时应该遵循的协议:

class Widget {
public:
    ...
    Widget& operator=(const Widget& rhs) {
        ...
        return *this;
    }
    ...
};

  这个协议不仅适用于以上的标准赋值形式,也适用于所有赋值相关运算,例如:

class Widget {
public:
    ...
    Widget& operator+=(const Widget& rhs) {
        ...
        return *this;
    }
    Widget& operator=(int rhs) {
        ...
        return *this;
    }
    ...
};

  注意:这只是个协议,并无强制性。如果不遵循它,代码一样可通过编译。然而这份协议被所有内置类型和标准程序库提供的类如string,vector,complex,trl:shared_ptr或即将提供的类型共同遵守。除非你有一个标新立异的好理由,否则还是遵循这条协议吧。

3.定义一个返回this对象的函数
  已知Sales_data类定义如下:

class Sales_data {
    std::string isbn() const {return bookNo;}
    Sales_data& combine(const Sales_data&);
    double avg_price() const;

    std::string bookNo;
    unsigned units_sold = 0;
    double revenue = 0.0;
};

  成员函数combine用于将一个Sales_data对象加到另一个对象上。函数combine的设计初衷类似于复合赋值运算符+=,调用该函数的对象代表的是赋值运算符的左侧的运算对象,右侧运算对象则通过显示的实参被传入函数:

Sales_data& Sales_data::combine(const Sales_data& rhs) {
    units_sold += rhs.units_sold;
    revenue += rhs.revenue;
    return *this;
}

  当我们调用如下函数时:

Sales_data total,trans;
total.combine(trans);

  total的地址被绑定到隐式的this参数上,而rhs绑定到了trans上。其中,return语句解引用this指针以获得执行该函数的对象,换句话说,上面这个调用返回total的引用。

4.请记住
令赋值(assignment)操作符返回一个reference to *this。

5.参考资料
- 《Effective C++》条款10
- 《C++ Primer》7.1 定义抽象数据类型

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值