实验六继承与派生.docxVIP

  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文档。上传文档
查看更多
继承与组合 一、 实验目的 了解继承在面向对象程序设计屮的重要作用。 进一步理解继承与派生的概念。 掌握通过继承派生出一个新的类的方法。 了解虚基类的作用和用法。 掌握类的组合 二、 实验内容 1.请先阅读下面的程序,写出程序运行的结果,然后再上机运行程序,验证自己分析的结 果是否正确。 (1) #include iostream using namespace std; class A {public: A(){cout?uA::A() called.n”;} virtual ~A(){cout?A::-A() calledAn;} }; class Bipublic A {public: B(int i) { cout?HB::B() caHed.\nM; buf=new char[i]; } virtual ~B() { delete [Jbuf; coutvvB::~B() called.\n; } private: char *buf; }; void fun(A *a) { cout?HMay you succeed!H?endl; delete a; } int main() { A *a=new B(15); fun(a); return 0; 1、 程序运行结果: A::A() called. called. May you succeed! called. A::~A() called. called. B: :BO called? May you succeed? B::~B called? R::~A called. frocess exited with peturn ualue 0 ress any key to continue ... ⑵ # includeiostream using namespace std; class A { public: A(int a,int b):x(a),y(b){ cout?HA constructo匚..H?endl; } void Add(int a.int b){ x+=a;y+=b;) void display(){ cout?,(?x?M,?y?)H;} -A(){ cout?Hdestructor A...H?endl;} private: int x,y; }; class B:private A{ private: int i,j; A Aobj; public: B(int a.int bjnt cjnt d):A(a,b),i(c)j(d) ,Aobj(l,l){ cout?lfB constructor...H?endl;} void Add(int x 1 ,int y 1 ,int x2,int y2) A::Add(xl,yl); i+=x2; j+二 y2; } void display(){ A::display(); Aobj.displayO; cout?,,(,,?i?,,;,?j?,,)n?endl; } ?B() {cout?Mdestructor B …” vvendl;} }; int main() { Bb(l,2,3,4); b.displayO; b.Add(l,3,5,7); b.displayO; return 0; } 程序运行结果: A constructor... A constructor… B constructor… (1,2) (1,1) (3,4) (2,5) (1,1) (8,11) destructor B… destructor A… destructor A… ⑶ #includeiostream using namespace std; class A { public: A(int a):x(a){ cout?nA constructor...n?x?endl; } int f(){ return ++x;} ?A() {cout?Mdestructor A...n?endl;} private: int x; }; class B:public virtual A{ private: inty; A Aobj; public: B(int a,int b,int c): A(a),y(c), Aobj(c) { cout?nB construct or. ..,f?y?endl;) intf(){ A::f(); Aobj.f(); return ++y; } void display(){ cout?A::f()?\tn?Aobj.f()?,\t?f()?endl; } ?B(){cout?Hdestructor B..n?endl;} }; class C:public

文档评论(0)

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

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

1亿VIP精品文档

相关文档