浅谈C++虚重载操作符 virtual operator= 的使用方法
更新时间:2017年01月08日 07:56:15 投稿:jingxian
下面小编就为大家带来一篇浅谈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++IO流之fstream, stringstream使用小结
C语言中常用的输入输出函数有如下几种:前者是格式化标准输入输出,后者是格式化文件输入输出,最后是格式化字符串输入输出,这篇文章主要介绍了C++IO流:fstream, stringstream总结,需要的朋友可以参考下2022-04-04
最新评论