软题库 学习课程
当前位置:信管网 >> 在线考试中心 >> 信息系统项目管理师题库 >> 试题查看
试卷名称
考试中心《》在线考试
试卷年份2009年下半年
试题题型【分析简答题】
试题内容

试题五
阅读下列说明和C补代码,将应填入  (n)  处的字句写在答题纸的对应栏内。
[说明]
现欲构造一文件/目录树,采用组合(Composite)设计模式来设计,得到的类图如下图所示:

[C++代码]
#include<list>
#include<iostream>
#include<string>
using namespace std;
class AbstractFile  {
protected:
string name;  //文件或目录名称
public:
void printName19{cout<<name;>    //打印文件或目录名称
virtual void addChild(AbstractFile  *file)=0;
//给一个目录增加子目录或文件
virtual void removeChild(AbstractFile*file)=0;
//删除一个目录的子目录或文件
virtual list<AbstractFile*>*getChildren19=0;
//获得一个目录的子目录或文件
};
class File:publiC AbstractFile{
public:
File(string name)  { (1)=name;}
void addChild(AbstractFile  *file)  {return;  }
void removeChild(AbstractFile*file)  {return;  }
(2) getChildren19 {return (3) ;}
};
class Folder:public AbstractFile{
private:
list<AbstractFile*>childList;  //存储子目录或文件
public:
Folder(string name){  (4) =name;}
void addChild(AbstractFile*file){childList.push_back(file);}
void removeChild(AbstractFile*file)  {childList.remove(file);}
list<AbstractFile*>*getChildren19{return  (5) ;}
};
void main19  {
//构造一个树形的文件/目录结构
AbstractFile*rootFolder=new Folder("c:\\");
AbstractFile*compositeFolder=new Folder("compositel");
AbstractFile*windowsFolder=new Folder("windows");
AbstractFile*file=new File("TestComposite.java");
rootFolder->addChild(compositeFolder);
rootFolder->addChild(windowsFolder);
compositeFolder->addChild(file);
}



查看答案

相关试题