■ 在前面的两种实现中,加法操作形式不符合数学上 的习惯: c=a+b C++允许对已有的操作符进行重载,使得它们能对 自定义类型(类)的对象进行操作 与函数名重载一样,操作符重载也是实现多态性的 种语言机制
◼ 在前面的两种实现中,加法操作形式不符合数学上 的习惯: c=a+b ◼ C++允许对已有的操作符进行重载,使得它们能对 自定义类型(类)的对象进行操作。 ◼ 与函数名重载一样,操作符重载也是实现多态性的 一种语言机制
操作符重载的基本原则 只能重载C++语言中已有的操作符,不可臆造 新的操作符。 可以重载C++中除下列操作符外的所有操作符: 99 6米刀 “sizeof 遵循己有操作符的语法: 不能改变操作数个数。 不改变原操作符的优先级和结合性。 尽量遵循已有操作符原来的语义: ·语言本身没有对此做任何规定,使用者自己把握!
操作符重载的基本原则 ◼ 只能重载C++语言中已有的操作符,不可臆造 新的操作符。 ◼ 可以重载C++中除下列操作符外的所有操作符: “. ” , “.* ” , “?: ” , “:: ” , “sizeof ” ◼ 遵循已有操作符的语法: • 不能改变操作数个数。 • 不改变原操作符的优先级和结合性。 ◼ 尽量遵循已有操作符原来的语义: • 语言本身没有对此做任何规定,使用者自己把握 !
操作符重载的实现途径 操作符重载可通过下面两个途径来实现: 01 作为一个类的非静态的成员函数(new和 delete除外) ·作为一个全局(友元)函数。 至少应该有一个参数是类、结构、枚举或它们的引 用类型
操作符重载的实现途径 ◼ 操作符重载可通过下面两个途径来实现: • 作为一个类的非静态的成员函数(new和 delete除外)。 • 作为一个全局(友元)函数。 ◼ 至少应该有一个参数是类、结构、枚举或它们的引 用类型
·以成员函数形式重载,例如: class Complex public: Complex operator +(const Complex&x)const Complex temp; temp.real real+x.real; temp.imagimag+x.imag; return temp; Complex a(1.0,2.0),b(3.0,4.0),c; c=a +b;
◼ 以成员函数形式重载,例如: class Complex { public: Complex operator + (const Complex& x) const { Complex temp; temp.real = real+x.real; temp.imag = imag+x.imag; return temp; } ...... }; …… Complex a(1.0,2.0),b(3.0,4.0),c; c = a + b;
·以全局函数形式重载,例如: class Complex { friend Complex operator +(const Complex&c1, const Complex&c2); Complex operator +(const Complex&c1, const Complex&c2) Complex temp; temp.real c1.real c2.real; temp.imag c1.imag c2.imag; return temp; } Complex a(1.0,2.0),b(3.0,4.0),c; c=a +b;
◼ 以全局函数形式重载,例如: class Complex { ...... friend Complex operator + (const Complex& c1, const Complex& c2); }; Complex operator + (const Complex& c1, const Complex& c2) { Complex temp; temp.real = c1.real + c2.real; temp.imag = c1.imag + c2.imag; return temp; } …… Complex a(1.0,2.0),b(3.0,4.0),c; c = a + b;