第十一周实践项目5————摩托车继承自行车和机动车
2016-05-05 19:05
344 查看
问题及代码:
运行结果:
![](http://img.blog.csdn.net/20160505190057545?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
学习心得:
虚基类是为了解决多个基类有共同基类时,这个最上层基类的成员会多次在最终派生类出现而产生二义性,为避免二义性,使得最终派生类中,最上层的基类成员只有一份,这时需要虚拟继承,该最上层类就是虚基类,需要注意的是,该类在第一层派生时就要虚拟继承才行,使用方法是在继承方式前加上一个
virtual就可以了。
/*copyright(c)2016.烟台大学计算机学院 * All rights reserved, * 文件名称:text.Cpp * 作者:吴敬超 * 完成日期:2016年5月4日 * 版本号:codeblock * * 问题描述: 摩托车继承自行车和机动车 * 输入描述: * 程序输出: 输出结果 */ #include <iostream> #include<conio.h> #include <windows.h> using namespace std; enum vehicleStaus {rest, running}; //车辆状态:泊车、行进 class vehicle //车辆类 { protected: int maxSpeed; //最大车速 int currentSpeed; //当前速度 int weight; //车重 vehicleStaus status; //rest-泊车状态;running-行进状态 public: vehicle(int maxS, int w); //构造函数,初始时,当前速度总为0且处在停车状态 void start(); //由rest状态到running, 初速为1 void stop(); //由running状态到rest, 当前速度小于5时,才允许停车 void speed_up(); //加速,调用1次,速度加1 void slow_down(); //减速,调用1次,速度减1,速度为0时,停车 }; vehicle::vehicle(int maxS,int w):maxSpeed(maxS),weight(w){} void vehicle::start() { if(status==rest) { status=running; currentSpeed=1; } else { cout<<"车辆已行驶"<<endl; } } void vehicle::stop() { if(status==running) { if(currentSpeed<=5) { status=rest; currentSpeed=0; } else { cout<<"不允许停车"<<endl; } } else { cout<<"车辆未启动"<<endl; } } void vehicle::speed_up() { if (status==running) if(currentSpeed<maxSpeed) ++currentSpeed; else cout<<"请不要超速行驶……"<<endl; else cout<<"车辆未启动!"<<endl; } void vehicle::slow_down() { if (status==running) { if(currentSpeed>0) --currentSpeed; } else cout<<"车辆未启动!"<<endl; if(currentSpeed==0) status=rest; } class bicycle :virtual public vehicle//(1)自行 车类的虚基类为车辆类 { protected: double height; //车高 public: bicycle(int maxS=10, int w=50, int h=0.7); //定义构造函数 }; bicycle::bicycle(int maxS,int w,int h):vehicle(maxS,w),height(h){} class motorcar :virtual public vehicle//(2)机动车类的虚基类也为车辆类 { protected: int seatNum; //座位数 int passengerNum; //乘客人数 public: motorcar(int maxS=150, int w=1500, int s=5, int p=1); //定义构造函数 void addPassenger(int p=1); //增加搭载的乘客,超员要拒载,有人下车时,p为负数。当然车上乘客至少有1个(司机)。只有车停稳后才能上下客。 }; motorcar::motorcar(int maxS,int w,int s,int p):vehicle(maxS,w),seatNum(s),passengerNum(p){} void motorcar::addPassenger(int p) { if (status==running) { cout<<"车辆正在行驶,停车后再上下车!"<<endl; } else { passengerNum+=p; if(passengerNum>seatNum) { passengerNum=seatNum; cout<<"涉嫌超员,已清理后达到满员!"<<endl; } else if (passengerNum<1) { passengerNum=1; cout<<"请司机不要离开岗位!"<<endl; } } } class motorcycle: public bicycle,public motorcar //(3)摩托车类的基类为自行车类和机动车类 { public: motorcycle(int maxS=90, int w=100, int s=3, int p=1, int h=0.7);//定义构造函数 void show(); //显示摩托车的运行状态 }; motorcycle::motorcycle(int maxS, int w, int s, int p, int h):vehicle(maxS, w),bicycle(maxS, w, h),motorcar(maxS, w, s, p) {} //显示摩托车的运行状态 void motorcycle::show() { cout<<"状态:"; if(status==rest) cout<<"泊车;\t"; else cout<<"行进;\t"; cout<<"车速:"<<currentSpeed<<" / "<< maxSpeed <<"\t当前乘员:"<<passengerNum<<" / "<< seatNum << endl; } int main( ) { motorcycle m; bool end=false; while (!end) { cout<<"请操作:1-启动 2-加速 3-减速 4-有人上车 5-有人下车 6-停车 0-结束"<<endl; char keydown= _getch(); //_getch()返回键盘上读取的字符 switch(keydown) { case '1': cout<<"选中的操作是1-启动\t"; m.start(); break; case '2': cout<<"选中的操作是2-加速\t"; m.speed_up(); break; case '3': cout<<"选中的操作是3-减速\t"; m.slow_down(); break; case '4': cout<<"选中的操作是4-有人上车\t"; m.addPassenger(); break; case '5': cout<<"选中的操作是5-有人下车\t"; m.addPassenger(-1); break; case '6': cout<<"选中的操作是6-停车\t"; m.stop(); break; case '0': end=true; break; } m.show(); cout<<endl; Sleep(200); //要包含头文件<windows.h> } return 0; }
运行结果:
学习心得:
虚基类是为了解决多个基类有共同基类时,这个最上层基类的成员会多次在最终派生类出现而产生二义性,为避免二义性,使得最终派生类中,最上层的基类成员只有一份,这时需要虚拟继承,该最上层类就是虚基类,需要注意的是,该类在第一层派生时就要虚拟继承才行,使用方法是在继承方式前加上一个
virtual就可以了。
相关文章推荐
- MySQL主从数据库同步延迟问题解决
- HTML5 audio标签使用 preload属性 规定是否在页面加载后载入音频
- php第十节课
- Storm处理流程, 基本参数配置
- Android 开发四大基本组件之一——Activity详解
- 线程安全与可重入函数
- PHP & HTML5 学习 第四课 PHP变量
- HTML加入CSS
- CentOS 7在grub rescue模式中修复系统
- 对各组意见的反馈(第一阶段)
- 导航栏上面添加UISearchBar pop回去的时候会把添加的导航栏带回去的问题
- Strom Topology执行分析:worker数,Bolt实例数,executor数,task数
- C++获取系统当前时间(精确到微秒)
- 第十周项目三 存储班长信息的学生类(1) (改法 2 )
- Centos 5 Oracle 11G 超详细安装
- js框架相关文章收藏
- 3Sum
- Leetcode - Longest Increasing Subsequence
- Android应用优化_0.1版本
- 通过IMM端口安装操作系统