- 1、本文档共12页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第21次课(运算符重载)
第21讲
教学内容
8.1 多态性概述
8.1.1多态的类型
8.1.2 多态的实现
8.2 运算符重载
8.2.1 运算符重载的规则
8.2.2 运算符重载为成员函数
8.2.3 运算符重载为友元函数
教学重点和难点
1多态的理解
2 运算符重载的作用
3 运算符重载的两种形式,了解如何重新定义(重载)运算符以处理新的抽象数据类型
教学方法:
通过举现实生活中的例子,讲解多态的概念。
通过程序举例演示,讲解运算符重载的作用,运算符重载的两种形式
教学学时
2 学时
教学过程
一 多态 :
1 多态性是面向对象程序设计的重要特征之一。
2多态性是指发出同样的消息被不同类型的对象接收时有可能导致完全不同的行为。
3多态的实现:
–函数重载
–运算符重载
–虚函数
二运算符重载:
1运算符重载的实质
1)如何将C++中的运算符和类对象结合一起使用,这个过程称为运算符重载(operator voerlonding)
3)必要性
–C++中预定义的运算符其运算对象只能是基本数据类型,而不适用于用户自定义类型(如类)
4)实现机制
–将指定的运算表达式转化为对运算符函数的调用,运算对象转化为运算符函数的实参。
编译系统对重载运算符的选择,遵循函数重载的选择原则。
2运算符重载的规则和限制:
1)可以重载C++中除下列运算符外的所有运算符:
. .* :: ?:
2)只能重载C++语言中已有的运算符,不可臆造新的。
3)不改变原运算符的优先级和结合性。重载运算符应该模拟其内部对象的功能。例如:+运算符重载后,应该仍然执行加法运算,而不是减法运算。
4)不能改变操作数个数。
5)经重载的运算符,其操作数中至少应该有一个是自定义类型。(运算符重载不能改变该运算符用于内部类型对象时的作用方式)
三 运算符重载的两种形式:
C++为其内部类型提供了丰富的运算符集,重载这些运算符的目的是为用户自定义的类型提供同样简洁的表达式,但运算符的重载不是自动完成的,程序员必须为所要执行的操作编写运算符函数,有时候把这些函数用作成员函数,有时最好用作友元函数,在极少数情况下,他们可能既不是成员函数,也不是友元函数。
1重载为成员函数:
当运算符函数作为成员函数实现时,最左边的操作数必须是运算符类的一个类对象(或者是该类对象的一个引用)。例如重载运算符(),[],-或者任何赋值运算符时,运算符函数必须声明为类的一个成员函数。
1)声明形式
函数类型 operator 运算符(形参)
{}
2)重载为类成员函数时 参数个数=原操作数个数-1 (后置++、--除外)
3)?双目运算符 B
–如果要重载 B 为类成员函数,使之能够实现表达式 oprd1 B oprd2,其中 oprd1 为A 类对象,则 B 应被重载为 A 类的成员函数,形参类型应该是 oprd2 所属的类型。
–经重载后,表达式 oprd1 B oprd2 相当于 oprd1.operator B(oprd2)
程序举例:
#include iostream
using namespace std;
class Complex
{
private:
int real;
int imag;
public:
Complex(int r,int i)
{
real = r;
imag = i;
}
Complex()
{
}
void disp()
{
cout real + imag iendl;
}
Complex operator +(Complex c2)//将+重载为成员函数,
//参数个数要少一个,因为另外一个参数用了this指针来实现
{
Complex temp;
temp.real = real + c2.real;//this-real
temp.imag = imag + c2.imag;//this-imag
return temp;
}
};
void main(void)
{
Complex c1(1,2);
c1.disp();
Complex c2(3,4);
c2.disp();
Complex c3;
//c3 = c1 + c2;
//c3 = c1.operator +(c2);//与上面c3 = c1+c2等价,但上面的写法要简洁清晰些。
//c3 = 10 + c1;//错误!不能10.operator+(c1)
//c3 = c1 +
文档评论(0)