继承和派生实验报告_第1页
继承和派生实验报告_第2页
继承和派生实验报告_第3页
继承和派生实验报告_第4页
继承和派生实验报告_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、精选优质文档-倾情为你奉上实验目的与要求:1. 掌握类的继承与派生关系以及实验方法,理解类的层次结构。2. 掌握派生类构造函数初始化基类成员和对象成员的方法。3. 掌握内联函数和默认函数。4. 掌握赋值兼容原则,掌握派生类的复制构造函数和赋值运算符的定义。实验过程及内容:1. 实践教程实验二十二P81范例:定义一个继承与派生关系的类体系,在派生类中访问基类成员。 先定义一个点类,包含x,y坐标数据成员,显示函数和计算面积的函数成员; 以点为基类派生一个圆类,增加表示半径的数据成员,重载显示和计算面积的函数; 定义一个线段类,以两个点类对象作数据成员,定义显示、求面积及长度函数,线段类采用聚合方

2、式,因为有两个端点,不能用派生。编程测试所定义的类体系。本实验教程中有源码,请自行运行,体会和熟悉继承与派生的基本概念及实现方法,掌握派生类构造函数初始化基类成员和对象成员的方法等。2. 实践教程P83编程:多层派生练习,由上题Point类和Circle类继续派生出Cylinder类。要求计算圆柱的底面积、侧面积、全面积和体积。请编写所有完整的成员函数,并编写主函数进行验证。数据处理1.(1) (2)j结果报错,原因是派生类中的成员函数不能访问基类中的私有成员。(3)在Line类中添加两个数据成员。2. #include <iostream>#include <cmath&g

3、t;using namespace std;#define PI 3.14159class Pointfriend class Line;protected:double x, y ; public:Point()x = 0 ; y = 0 ; Point(double xv,double yv) x = xv; y = yv; double Area()return 0;void Show()cout<<"x="<<x<<' '<<"y="<<y<<endl;cla

4、ss Circle :public Pointprotected:double radius;public:Circle() x = 0; y = 0; radius = 0; Circle(double xv,double yv,double vv):Point(xv,yv) /调用基类构造函数radius = vv;Circle(Circle & cir):Point(cir) /按赋值兼容规则cir可为Point实参radius=cir.radius;Circle & operator=(Circle & cir)this->Point:operator=(

5、cir); /在派生类中定义重载的拷贝赋值操作符有固定的标准格式radius=cir.radius;return *this;double Area()return PI*radius*radius;void Show()cout<<"x="<<x<<' '<<"y="<<y<<" radius="<<radius<<endl; /访问基类的数据成员;class Cylinder:public Circle double h

6、igh;public:Cylinder() x = 0; y = 0; radius = 0;high=0; Cylinder(double xv,double yv,double vv,double kv):Circle(xv,yv,vv) /调用基类构造函数high=kv;Cylinder(Cylinder & cyl):Circle(cyl) /按赋值兼容规则cyl可为Cylinder实参high=cyl.high;Cylinder & operator=(Cylinder & cyl)this->Circle : operator=(cyl); /在派生类

7、中定义重载的拷贝赋值操作符有固定的标准格式high=cyl.high;return *this; double ceArea()return 2*PI*radius*high;double quArea()return ceArea()+2* Area();double volume()return Area()*high;void Show() cout<<"x="<<x<<' '<<"y="<<y<<' '<<"radius=

8、"<<radius<<' '<<"high="<<high<<endl; /访问基类的数据成员;class LinePoint start,end;/对象成员public:Line() /对象成员初始化Line(double xv1,double yv1,double xv2,double yv2) : start(xv1,yv1),end(xv2,yv2) double GetLength()return sqrt(start.x-end.x)*(start.x-end.x)+(star

9、t.y-end.y)*(start.y-end.y);double Area()return 0;void Show()cout<<"start point:n"start.Show();cout<<"end point:n"end.Show();int main()Point pt(0,0);Circle cl1(100,100,10),cl2(cl1),cl3;Cylinder h1(50,50,20,30),h2(h1),h3;Line ln1(0,0,100,100),ln2;cout<<"点面积:&

10、quot;<<pt.Area()<<endl;pt.Show();cout<<"cl1圆面积:"<<cl1.Area()<<endl;cl1.Show();cout<<"cl2圆面积:"<<cl2.Area()<<endl;cl2.Show();cl3=cl1;cout<<"cl3圆面积:"<<cl3.Area()<<endl;cl3.Show();cout<<"h1底面积:&quo

11、t;<<h1.Area()<<endl;cout<<"h1侧面积:"<<h1.ceArea()<<endl;cout<<"h1全面积:"<<h1.quArea()<<endl; cout<<"h1体积:"<<h1.volume()<<endl; h1.Show(); cout<<"h2底面积:"<<h2.Area()<<endl;cout<&l

12、t;"h2侧面积:"<<h2.ceArea()<<endl;cout<<"h2全面积:"<<h2.quArea()<<endl; cout<<"h2体积:"<<h2.volume()<<endl; h2.Show(); h3=h1; cout<<"h3底面积:"<<h3.Area()<<endl;cout<<"h3侧面积:"<<h3.ceArea()<<endl;cout<<"h3全面积:"<<h3.quArea()<<endl; cout<<"h3体积:"<<h3.volume()<<endl; h3.Show();cout<<"线面积:"<<ln1. Area()<<'t'<<"线长度:&quo

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论