浅谈C++虚重载操作符 virtual operator= 的使用方法

C++中虚操作符和其他虚函数的规则一样,操作符可以为虚函数,进行动态绑定, 虽然这种情况并不多见。本文以赋值操作符operator=举例。

派生类中要重定义基类虚函数,要注意参数必须为基类引用类型,否则与基类中虚函数是完全不同的,无法进行预期的动态绑定。

派生类除了重定义基类的虚操作符,还要定义自身的操作符重载。即派生层次每增加一层,理论上派生类就需要多定义一个操作符重载。

以下程序使用引用reference,通过指针调用赋值操作符(例:*p = value)情况是一样的。

#include <iostream> 
using namespace std; 
               
class Base 
{ 
public: 
  virtual Base& operator=(const Base& rhs) //重载操作符可设为virtual 
  { 
    cout << "Base" << endl; 
    return *this; 
  } 
}; 
               
class Derived : public Base 
{ 
public: 
  //与基类的operator=完全不同,不是重新定义,不会动态绑定。 
  //如果不定义该操作符,会自动合成一个,并自动调用基类的operator=,不会动态绑定 
  Derived& operator=(const Derived& rhs)  
  { 
    cout << "Derived_D" << endl; 
    return *this; 
  } 
               
  //重新定义基类的operator=,会动态绑定 
  //virtual Base& operator=(const Base& rhs) //返回值两种都可以 
  virtual Derived& operator=(const Base& rhs)  
  { 
    cout << "Derived_B" << endl; 
    return *this; 
  } 
}; 
               
class Derived2 : public Derived 
{ 
  //此类需要3个operator= 
  //可定义private的copy函数,由3个operator=调用 
  //可使用dynamic_cast将基类引用参数转为子类,并捕获异常。 
  //如果未发生异常,则调用copy,发生异常则不需赋值 
}; 
               
int main() 
{ 
  Base b1,b2; 
  Derived d1,d2; 
               
  Derived &rd = d1; 
               
  Base &rb1 = b1; //动态类型为Base 
  Base &rb2 = d2; //动态类型为Derived 
                 
  rb1 = d1; //输出"Base" 
  rb2 = d2; //输出"Derived_B" 
               
  rb1 = rb2; //输出"Base" 
  rb2 = rb1; //输出"Derived_B" 
               
  rd = d1; //输出"Derived_D" 
  rd = b1; //输出"Derived_B" 
                 
  getchar(); 
  return 0; 
}

以上就是小编为大家带来的浅谈C++虚重载操作符 virtual operator= 的使用方法全部内容了,希望大家多多支持编程小技巧~

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...