文档详情

C语言程序设计多态性.ppt

发布:2016-03-24约7.21千字共39页下载文档
文本预览下载声明
* * * * * * * * * * * * * * * * * * * 程序运行结果为: First time output: 23:59:59 Show myClock++: 23:59:59 Show ++myClock: 0:0:1 * 运算符友元函数的设计 如果需要重载一个运算符,使之能够用于操作某类对象的私有成员,可以此将运算符重载为该类的友元函数。 函数的形参代表依自左至右次序排列的各操作数。 后置单目运算符 ++和--的重载函数,形参列表中要增加一个int,但不必写形参名。 * 运算符重载 运算符友元函数的设计 双目运算符 B重载后, 表达式oprd1 B oprd2 等同于operator B(oprd1,oprd2 ) 前置单目运算符 B重载后, 表达式 B oprd 等同于operator B(oprd ) 后置单目运算符 ++和--重载后, 表达式 oprd B 等同于operator B(oprd,0 ) * 运算符重载 例8-3 将+、-(双目)重载为复数类的友元函数。 两个操作数都是复数类的对象。 * 运算符重载 #includeiostream using namespace std; class complex //复数类声明 {public: //外部接口 complex(double r=0.0,double i=0.0) { real=r; imag=i; } friend complex operator + (complex c1,complex c2); //运算符+重载为友元函数 friend complex operator - (complex c1,complex c2); //运算符-重载为友元函数 friend ostream operator (ostream out, const complex c);//运算符重载为友元函数 void display(); //显示复数的值 private: //私有数据成员 double real; double imag; }; * complex operator +(complex c1,complex c2) //运算符重载友元函数实现 { return complex(c2.real+c1.real, c2.imag+c1.imag); } complex operator -(complex c1,complex c2) //运算符重载友元函数实现 { return complex(c1.real-c2.real, c1.imag-c2.imag); } * * ostream operator (ostream out , const complex c) //运算符重载友元函数实现 { out“(”c.real“,”c.imag“)”; return out; } int main(){ complex c1(5,4),c2(2,10), c3; cout“c1=”c1endl; cout“c2=”c2endl; c3=c1-c2; cout“c3=c1-c2=”c3endl; c3=c1+c2; cout“c3=c1+c2=”c3endl; } 虚函数 问题:P233—通过基类的指针,只能访问从基类继承的成员。 解决:通过基类的指针指向派生类的对象,能够访问派生中与基类同名的成员 方法:虚函数 * 虚 函 数 虚函数 虚函数是非静态的成员函数。 在类的声明中,在函数原型之前写virtual。 virtual 只用来说明类声明中的原型,不能用在函数实现时。 具有继承性,基类中声明了虚函数,派生类中无论是否说明,同原型函数都自动为虚函数。 本质:不是重载声明而是覆盖。 调用方式:通过基类指针或引用,执行时会 根据指针指向的对象的类,决定调用哪个函数。 * 虚 函 数 例 8.4 #include iostream using namespace std; class B0 //基类B0声明 {public: //外部接口 virtual void display() //虚成员函数 {coutB0::display()endl;} }; class B1: public B0 //公有派生 { public: void display() { coutB1::display()endl; } }; class D1: public B1 //公有派生 { public: void display() { coutD1::display()endl; } }; * 虚 函
显示全部
相似文档