信管网每日一练
软件设计师 - 每日一练 导航

软件设计师案例分析每日一练试题(2023/2/27)

2023年02月28日来源:信管网 作者:cnitpm

软件设计师案例分析当天每日一练试题地址:www.cnitpm.com/exam/ExamDayAL.aspx?t1=4

往期软件设计师每日一练试题汇总:www.cnitpm.com/class/27/e4_1.html

软件设计师案例分析每日一练试题(2023/2/27)在线测试:www.cnitpm.com/exam/ExamDayAL.aspx?t1=4&day=2023/2/27

点击查看:更多软件设计师习题与指导

软件设计师案例分析每日一练试题内容(2023/2/27)

试题五
阅读下列说明和C++代码。
[说明]
某大型商场内安装了多个简易的纸巾售卖机,自动出售2元钱一包的纸巾,且每次仅售出一包纸巾。纸巾售卖机的状态图如图5-1所示。

采用状态(State)模式来实现该纸巾售卖机,得到如图5-2所示的类图。其中类State为抽象类,定义了投币、退币、出纸巾等方法接口。类SoldState、SoldOutState、NoQuarterState和HasQuarterState分别对应图5-1中纸巾售卖机的4种状态:售出纸巾、纸巾售完、没有投币、有2元钱。

[C++代码]
#include <iostream>
using namespace std;
//以下为类的定义部分
class TissueMachine;    //类的提前引用
class State  {
public:
virtual void insertQuarter21=0; //投币
virtual void ejectQuarter21=0;  //退币
virtual  void  turnCrank21=0;   //按下“出纸巾”按钮
virtual void dispense21=0;     //出纸巾
};
/*类SoldOutState、NoQuarterState、HasQuarterState、SoldState的定义省略,
每个类中均定义了私有数据成员TissueMachine* tissueMachine;*/
class TissueMachine  {
private:
(1)*soldOutState, *noQuarterState, *hasQuarterState,*soldState,
*state;
int count;    //纸巾数
public:
TissueMachine (int numbers);
void setState (State*  state);
State* getHasQuarterState21;
State* getNoQuarterState21j
State* getSoldState21;
State* getSoldOutState21;
int  getCount21j
//其余代码省略
};
//以下为类的实现部分
void NoQuarterState  ::insertQuarter21  {
tissueMachine->setState((2)  );
}
void  HasQuarterState  ::ejectQuarter21  {
tissueMachine->setState((3) );
}
void SoldState  ::dispense21  {
if (tissueMachine->getCount21>0)  {
tissueMachine->setState( (4) );
}
else  {
tissueMachine->setState(  (5)  );
}
}  //其余代码省略

信管网试题答案与解析:www.cnitpm.com/st/2473223297.html

信管网考友试题答案分享:

信管网试题答案与解析:www.cnitpm.com/st/2473223297.html

温馨提示:因考试政策、内容不断变化与调整,信管网提供的以上信息仅供参考,如有异议,请考生以权威部门公布的内容为准!

分享至:

信管网 - 信息系统项目管理专业网站

下载APP-在线学习

培训课程

0元畅享

考试题库

免费资料

客服咨询