- 1、本文档共56页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第九章 多态性 丘志杰 电子科技大学 计算机学院 软件学院 什么是多态性 多态是指同样的消息被不同类型的对象接收时导致完全不同的行为。 多态性的分类 编译时的多态 运算符重载的引入 当在使用C++编写程序时,我们不仅要使用基本数据类型,还要设计新的数据类型—类类型。 对于基本数据类型,就隐含着运算符重载的概念。 此时,需要一种特别的机制来重新定义运算符作用在类类型上的含义。 重载运算符 大多数系统预定义的运算符可以重载,但少数的C++运算符不能重载: 例:复数的加操作 class Complex{ double re, im; public: Complex(double r=0.0, double i=0.0): re(r), im(i){ } Complex add(Complex c){ Complex t; t.re = re + c.re; t.im = im + c.im; return t; } }; 例:重载复数类的加运算符 void main( ) { Complex c1(1, 2), c2(3, 4); Complex c3 = c1 + c2; } 用成员函数形式重载运算符 运算符是通过运算符重载函数来完成重载的。 例:计数器类重载运算符 class Counter{ int value; public: Counter( ){value=0;} void operator++( ); void operator--( ); int operator( )( ); }; void main( ) { Counter my_counter; for(int i=0;i2;i++){ ++my_counter; cout“my_counter=“my_counter( )endl; } --my_counter; cout“my_counter=“my_counter( )endl; } 用成员函数重载运算符可能会碰到的麻烦 class Complex{ …… public: Complex operator+(Complex c){ Complex t; t.re = re + c.re; t.im = im + c.im; return t; } }; 用友元函数形式实现运算符重载,能够很容易地将27隐式转换为Complex类型 例子:用友元重载运算符 一元运算符 对任意一元运算符@,将其作为成员函数重载时的定义及调用方式为: 将一元运算符@作为友元函数重载时的定义及调用方式为: 二元运算符 将一元运算符@作为成员函数重载时的定义及调用方式为: 将二元运算符@作为友元函数重载时的定义及调用方式为: 几点注意 当运算符被重载时,它是被绑定在一个特定的类类型之上的。当此运算符不作用在特定类类型上时,它将保持原有的含义。 例子:用友元重载++运算符 class Counter{ int value; public: public: Counter(int v=0){value=v;} friend Counter operator++( Counter obj); }; Counter operator++(Counter obj){ obj.value++; return obj; } 重载++和-- 运算符++和--有两种使用方式:前缀和后缀。因此在重载这两个运算符时,应该考虑到这两种方式的差别。 对于前缀方式++obj 成员函数方式 type className::operator++( ); 友元函数方式 type operator++(className); class Counter{ int value; public: Counter(int v=0){value=v;} }; 重载运算符 [ ]:整型数组类IntArray 重载赋值运算符= 举例(一) class Complex{ double re, im; public: Complex(double r=0.0, double i=0.0): re(r), im(i){ } Complex(Complex obj){ re=obj.re; im=obj.im; } Complex operator=(Complex obj){ re=obj.re; im=obj.im; return *this; } …… }; 赋值运算符与拷贝构造函数的异同 相同点:它们的目的都是为了将一个对象的数据成员复制到另一个
文档评论(0)