资源描述
第五章多态性,多态性:用同样接口访问功能不同的函数。静态联编和动态联编动态联编:程序运行时根据指针实际的指向来确定运行函数,指向基类的指针虚函数(在基类中定义)根据赋值兼容规则,可使用派生类的对象代替基类的对象。利用基类类型的指针指向派生类,可以通过这个指针来使用派生类的成名函数。如果这个成员函数是普通的成员函数,通过基类类型的指针访问的是基类的同名函数;如果成员函数是虚函数,则可使用基类类型的指针访问该指针正在指向的派生类的同名函数虚函数的访问权限不影响对它进行动态联编在派生类中定义的同名函数,参数个数和相应类型以及返回类型与基类完全一样,则有无virtual都是虚函数构造函数不能是虚函数,析构函数可以是虚函数虚函数不能是友元函数,不能是静态成员函数,classbase1public:virtualvoidfun(inti)coutfun(10);,classbase1public:virtualvoidfun(inti)coutfun(10);p2=,classbase1public:virtualvoidfun(inti)coutfun(10);p2=,第五章多态性,在构造函数和析构函数中调用虚函数:采用静态联编,即调用自己或基类的page例5_4纯虚函数与抽象类class类名virtual类型函数名(参数列表)=0;纯虚函数不能在构造函数中调用,classbasepublic:intx;base(inta)x=a;coutfun1();pBase-fun2();pDerived-fun1();pDerived-fun2();,base():5derived():25fun1inderived:25fun2inbase:5fun1inderived:25fun2inderived:25derived():25base():5,勘误表,P100“并且假设有指针pa、pb、pc并说明如下(第二行)B*pb;P102例题第六行pa-fb();,例题分析,对于类定义classApublic:virtualvoidfunc1()voidfunc2();classB:publicApublic:voidfunc1()cout“classBfunc1”endl;virtualvoidfunc2()cout“classBfunc2”A:func()将A.调用类A中的函数func()B.调用类B中的函数func()C.根据p所指的对象类型而确定调用类A中或类B中的函数func()D.既调用类A中的函数,也调用类B中的函数,A,C+支持两种多态性分别是多态性和多态性,编译时的,运行时的,要在调用虚函数的时候强制进行静态联编,可以通过在调用中对虚函数加实现。,成员名限定,写出下面程序的输出结果,例题分析,#includetemplateTf(T*a,T*b,intn)Ts=(T)0;for(inti=0;in;i+)s+=ai*bi;returns;voidmain()doublec5=1.1,2.2,3.3,4.4,5.5,d5=10.0,100.0,1000.0;coutf(c,d,5)endl;输出为:,3531,写出下面程序的输出结果,#includetemplatevoidf(Ta33,Tb33,Tc33)for(inti=0;i3;i+)for(intj=0;j3;j+)cij=(T)0;for(intk=0;k3;k+)cij+=aik*bjk;voidmain()inta33=1,2,3,4,5,6,7,b33,c33=2,0,2,0,0,2;f(a,c,b);for(inti=0;i3;i+)for(intj=0;j3;j+)coutbij“;coutendl;,246810121400,
展开阅读全文