导航
您当前的位置:首页 > 计算机 > 软件水平
问题:

[问答题] 现欲构造一文件/目录树,采用组合(Composite)设计模式来设计,得到的类图如5-1所示:中级软件设计师,历年真题,2009年下半年(下午)《软件设计师》真题图5-1类图【C++代码】#include<List>#include<iostrem>#include<string>using namespace std;class AbstractFile{protected:string name;//文件或目录名称public:void printName(  ){cout<<name;}//打印文件或目录名称virtual void addChild(AbstractFile*file)=0;//给一个目录增加子目录或文件virtual void removeChild(AbstractFile*file)=0;//删除一个目录的子目录或文件virtual list<AbstractFile*>*getChildren(  )=0;//获得一个目录的子目录或文件};class File:public AbstracFile{public:File(string name){(1)=name;}void addChild(AbstractFile*file){return;}void removeChild(AbstractFile*file){return;}(2)getChildren(  ){return(3);}};classFolder: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*>*getChildren(  ){return(5);}};void main(  ){//构造一个树形的文件/目录结构AbstractFile*rootFolder=new Folder(“c:\\”);AbstractFile*compositeFolder=new Folder(“composite”);AbstractFile*windowsFolder=new Folder(“windows”);AbstractFile*file=new File(“TestComposite.java”);rootFolder->addChild(compositeFolder);rootFolder->addChild(windowsFolder);compositeFolder->addChild(file);}中级软件设计师,历年真题,2009年下半年(下午)《软件设计师》真题图5-1类图【C++代码】#include<List>#include<iostrem>#include<string>using namespace std;class AbstractFile{protected:string name;//文件或目录名称public:void printName(  ){cout<<name;}//打印文件或目录名称virtual void addChild(AbstractFile*file)=0;//给一个目录增加子目录或文件virtual void removeChild(AbstractFile*file)=0;//删除一个目录的子目录或文件virtual list<AbstractFile>*getChildren(  )=0;//获得一个目录的子目录或文件};class File:public AbstractFile{public:File(string name){(1)=name;}void addChild(AbstractFile*file){return;}void removeChild(AbstractFile*file){return;}(2)getChildren(  ){return(3);}};classFolder: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*>*getChildren(  ){return(5);}};void main(  ){//构造一个树形的文件/目录结构AbstractFile*rootFolder=new Folder(“c:\\”);AbstractFile*compositeFolder=new Folder(“composite”);AbstractFile*windowsFolder=new Folder(“windows”);AbstractFile*file=new file(“TestComposite.java”);rootFolder->addChild(compositeFolder);rootFolder->addChild(windowsFolder);compositeFolder->addChild(file);}
答案解析:

相关问题
关于我们 | 用户指南 | 版权声明 | 给我留言 | 联系我们 | 积分商城 | 答案求助 | 网站地图
Copyright © 2024 www.daanwo.com All Rights Reserved