欢迎来到天天文库
浏览记录
ID:1967836
大小:43.50 KB
页数:5页
时间:2017-11-14
《实验4虚函数与多态-参考程序》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、《C++程序设计×2》实验4:虚函数与多态参考程序一、实验目的1、学会定义和使用纯虚函数。2、在掌握继承与派生关系的基础上,进一步理解虚函数与多态性的关系,实现运行时的多态性。3、理解虚函数在类的继承层次中的作用,虚函数的引入对程序运行时的影响,能够对使用虚函数的简单程序写出程序结果。二、实验内容及步骤1.现有称为figure的基类,存放二维对象(三角形、矩形和圆形三个类)的各维数据,并由set_dim()设置数据,它是标准成员函数。show_area()为虚函数,因为计算三角形、矩形和圆形三个类对象的面积的方法是不同的,需重新定义。1、参考程序代码:#include2、am>usingnamespacestd;classfigure{protected:doublex,y;public:voidset_dim(doublei,doublej=0){x=i;y=j;}virtualvoidshow_area(){cout<<"Noareacomputationdefinedforthisclass.";}};classtriangle:publicfigure{public:voidshow_area(){cout<<"Trianglewithheight"<3、ndl;}};classsquare:publicfigure{public:voidshow_area(){cout<<"Squarewithdimensions"<se4、t_dim(10.0,5.0);p->show_area();p=&s;p->set_dim(10.0,5.0);p->show_area();p=&c;p->set_dim(10.0);p->show_area();return0;}参考运行结果:2、分析以下程序的运行结果,并上机进行验证。#includeclassbase{public:base(){fc();}virtualvoidfc(){cout<<"Inclassbase"<5、};classA:publicbase{public:A(){fc();}voidf(){fc();}~A(){fd();}voidfd(){cout<<"DestructingAobject"<6、,静态联编调用base::fc(),输出“Inclassbase”。接着调用类A的构造函数,也使用的是静态联编。但是A内没有函数fc的定义,这时就调用类base::fc()。仍然输出“Inclassbase”。接着才调用类B自己的构造函数,但这个函数是空的,什么输出也没有。接着执行B::fc(),显然是静态联编。接着建立一个类A的对象并用一个指向基类的指针指向它。这时先调用类base的构造函数,这是静态联编,输出“Inclassbase”。再调用类A的构造函数,同样输出“Inclassbase”,这也是静态联编。下面执行deletep,先调用A的析构函数,输出“Destructin7、gAobject”,这是静态联编。接着base中的纯虚析构函数被调用,输出"Destructingbaseobject",也是静态联编。程序执行到了最后,要清除对象b,依次调用B::~B()(实际调用B::fd()),A::~A()(实际调用A::fd()),base::~base(),都是静态联编。输出依次为:"DestructingBobject"、"DestructingAobject"和"Destructingbaseobject"。参考运行结果:3、3、分析
2、am>usingnamespacestd;classfigure{protected:doublex,y;public:voidset_dim(doublei,doublej=0){x=i;y=j;}virtualvoidshow_area(){cout<<"Noareacomputationdefinedforthisclass.";}};classtriangle:publicfigure{public:voidshow_area(){cout<<"Trianglewithheight"<3、ndl;}};classsquare:publicfigure{public:voidshow_area(){cout<<"Squarewithdimensions"<se4、t_dim(10.0,5.0);p->show_area();p=&s;p->set_dim(10.0,5.0);p->show_area();p=&c;p->set_dim(10.0);p->show_area();return0;}参考运行结果:2、分析以下程序的运行结果,并上机进行验证。#includeclassbase{public:base(){fc();}virtualvoidfc(){cout<<"Inclassbase"<5、};classA:publicbase{public:A(){fc();}voidf(){fc();}~A(){fd();}voidfd(){cout<<"DestructingAobject"<6、,静态联编调用base::fc(),输出“Inclassbase”。接着调用类A的构造函数,也使用的是静态联编。但是A内没有函数fc的定义,这时就调用类base::fc()。仍然输出“Inclassbase”。接着才调用类B自己的构造函数,但这个函数是空的,什么输出也没有。接着执行B::fc(),显然是静态联编。接着建立一个类A的对象并用一个指向基类的指针指向它。这时先调用类base的构造函数,这是静态联编,输出“Inclassbase”。再调用类A的构造函数,同样输出“Inclassbase”,这也是静态联编。下面执行deletep,先调用A的析构函数,输出“Destructin7、gAobject”,这是静态联编。接着base中的纯虚析构函数被调用,输出"Destructingbaseobject",也是静态联编。程序执行到了最后,要清除对象b,依次调用B::~B()(实际调用B::fd()),A::~A()(实际调用A::fd()),base::~base(),都是静态联编。输出依次为:"DestructingBobject"、"DestructingAobject"和"Destructingbaseobject"。参考运行结果:3、3、分析
3、ndl;}};classsquare:publicfigure{public:voidshow_area(){cout<<"Squarewithdimensions"<se
4、t_dim(10.0,5.0);p->show_area();p=&s;p->set_dim(10.0,5.0);p->show_area();p=&c;p->set_dim(10.0);p->show_area();return0;}参考运行结果:2、分析以下程序的运行结果,并上机进行验证。#includeclassbase{public:base(){fc();}virtualvoidfc(){cout<<"Inclassbase"<5、};classA:publicbase{public:A(){fc();}voidf(){fc();}~A(){fd();}voidfd(){cout<<"DestructingAobject"<6、,静态联编调用base::fc(),输出“Inclassbase”。接着调用类A的构造函数,也使用的是静态联编。但是A内没有函数fc的定义,这时就调用类base::fc()。仍然输出“Inclassbase”。接着才调用类B自己的构造函数,但这个函数是空的,什么输出也没有。接着执行B::fc(),显然是静态联编。接着建立一个类A的对象并用一个指向基类的指针指向它。这时先调用类base的构造函数,这是静态联编,输出“Inclassbase”。再调用类A的构造函数,同样输出“Inclassbase”,这也是静态联编。下面执行deletep,先调用A的析构函数,输出“Destructin7、gAobject”,这是静态联编。接着base中的纯虚析构函数被调用,输出"Destructingbaseobject",也是静态联编。程序执行到了最后,要清除对象b,依次调用B::~B()(实际调用B::fd()),A::~A()(实际调用A::fd()),base::~base(),都是静态联编。输出依次为:"DestructingBobject"、"DestructingAobject"和"Destructingbaseobject"。参考运行结果:3、3、分析
5、};classA:publicbase{public:A(){fc();}voidf(){fc();}~A(){fd();}voidfd(){cout<<"DestructingAobject"<6、,静态联编调用base::fc(),输出“Inclassbase”。接着调用类A的构造函数,也使用的是静态联编。但是A内没有函数fc的定义,这时就调用类base::fc()。仍然输出“Inclassbase”。接着才调用类B自己的构造函数,但这个函数是空的,什么输出也没有。接着执行B::fc(),显然是静态联编。接着建立一个类A的对象并用一个指向基类的指针指向它。这时先调用类base的构造函数,这是静态联编,输出“Inclassbase”。再调用类A的构造函数,同样输出“Inclassbase”,这也是静态联编。下面执行deletep,先调用A的析构函数,输出“Destructin7、gAobject”,这是静态联编。接着base中的纯虚析构函数被调用,输出"Destructingbaseobject",也是静态联编。程序执行到了最后,要清除对象b,依次调用B::~B()(实际调用B::fd()),A::~A()(实际调用A::fd()),base::~base(),都是静态联编。输出依次为:"DestructingBobject"、"DestructingAobject"和"Destructingbaseobject"。参考运行结果:3、3、分析
6、,静态联编调用base::fc(),输出“Inclassbase”。接着调用类A的构造函数,也使用的是静态联编。但是A内没有函数fc的定义,这时就调用类base::fc()。仍然输出“Inclassbase”。接着才调用类B自己的构造函数,但这个函数是空的,什么输出也没有。接着执行B::fc(),显然是静态联编。接着建立一个类A的对象并用一个指向基类的指针指向它。这时先调用类base的构造函数,这是静态联编,输出“Inclassbase”。再调用类A的构造函数,同样输出“Inclassbase”,这也是静态联编。下面执行deletep,先调用A的析构函数,输出“Destructin
7、gAobject”,这是静态联编。接着base中的纯虚析构函数被调用,输出"Destructingbaseobject",也是静态联编。程序执行到了最后,要清除对象b,依次调用B::~B()(实际调用B::fd()),A::~A()(实际调用A::fd()),base::~base(),都是静态联编。输出依次为:"DestructingBobject"、"DestructingAobject"和"Destructingbaseobject"。参考运行结果:3、3、分析
此文档下载收益归作者所有