c++第05章多态与抽象类2013年12月10日.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
c第05章多态与抽象类2013年12月10日

* class Student { public: virtual void print()    //定义虚函数 { coutA studentendl; } }; class GStudent:public Student { public: virtual void print() { coutA graduate studentendl; } }; void fun(Student s) //对象引用作参数 { s.print(); //采用对象引用调用虚函数 } int main() { Student s1; GStudent s2; fun(s1); fun(s2); return 0; } A student A graduate student 【例5-6】采用对象引用调用虚函数,进而实现动态联编。 * 只要定义一个基类的对象指针或对象引用,就可以调用期望的虚函数。 在实际应用中,不必过多地考虑类的层次关系,无须显式地写出虚函数的路径,只须将对象指针指向相应的派生类或引用相应的对象,通过动态联编就可以对消息做出正确的反应。 * 虚函数小结 如果期望在派生类中重新定义一个成员函数,那么就应该在基类中把该函数设为virtual。 以单一指令调用不同函数,这种性质就是“多态”。 虚函数是C++语言的多态性质和动态绑定的关键。 虚函数派生下去仍是虚函数,而且可以省略virtual关键词。 * Employee Salesman Manager Technician Emloyee e1; Technician t1; Salesman s1; Manager m1; Employee *emp[4]={e1,t1,s1,m1}; for(int i=0;i4;i++) { emp[i]-Display(); } 用指向基类对象的指针数组来处理多个派生类对象 虚函数 * 一般来说,可将类簇中具有共性的成员函数声明为虚函数,而具有个性的函数没有必要声明为虚函数。但是下面的情况例外: 静态成员函数不能声明为虚函数。因为静态成员函数不属于某一个对象,没有多态性的特征。 * 构造函数不能是虚函数。构造函数是在定义对象时被调用,完成对象的初始化,此时对象还没有完全建立。虚函数作为运行时的多态性的基础,主要是针对对象的,而构造函数是在对象产生之前运行的。所以,将构造函数声明为虚函数是没有意义的。 内联成员函数不能声明为虚函数。因为内联函数的执行代码是明确的,在编译时已被替换,没有多态性的特征。如果将那些在类声明时就定义内容的成员函数声明为虚函数,此时函数不是内联函数,而以多态性出现。 * 析构函数可以是虚函数。比如释放内存时,由于实施多态性时是通过将基类的指针指向派生类的对象来完成的,如果删除该指针,就会调用该指针指向的派生类的析构函数,而派生类的析构函数又自动调用基类的析构函数,这样整个派生类的对象才被完全释放。 * 虚析构函数 虚析构函数的声明格式如下: virtual ~类名(); 如果一个类的析构函数是虚函数,那么,由它派生的所有子类的析构函数也是虚函数。 * class Base { public: ~Base(){ cout Base destructorendl; } }; class Derived: public Base { public: Derived(); ~Derived(); private: int *iptr; }; Derived::Derived() { iptr=new int(0) ; } Derived::~Derived() { coutDerived destructorendl; delete iptr; } void fun(Base *b) { delete b; } int main() { Base *b=new Derived(); fun(b); return 0; } Base destructor 【例5-7】虚析构函数示例。 Derived destructor Base destructor virtual * class A { public: ~A() { coutcall A::~A()endl; } }; class B:public A { public: B(int

文档评论(0)

sandaolingcrh + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档