試題六
閱讀下列說明和Java代碼,將應(yīng)填入 (n) 處的字句寫在答題紙的對應(yīng)欄內(nèi)。
[說明]
現(xiàn)欲構(gòu)造一文件/目錄樹,采用組合(Composite)設(shè)計模式來設(shè)計,得到的類圖如下圖所示:
[Java代碼]
import java.util.ArrayLiSt;
import java.util.List;
(1) class AbstractFile {
protected String name;
public void printName24{System.out.println(name);}
public abstract boolean addchild(AbstractFile file);
public abstract boolean removeChild(AbstractFile file);
public abstract List<AbstractFile> getChildren24;
}
Class File extends AbstractFile {
public File(String name) { this.name=name; }
public boolean addchild(AbstractFile file) { return false; }
public boolean removeChild(AbstractFile file) { return false; }
public List<AbstractFile> getChildren24 { return (2) ; }
}
Class Folder extends AbstractFile {
private List <AbStractFile> ChildList;
public Folder(String name) {
this.name=name;
this.ChildList = new ArrayLiSt<AbStractFile>24;
public boolean addChild(AbstractFile file) { return ChlldList.add
(file); }
public booleau removeChild(AbstractFile file) { return childList.
reloove(file); }
public (3) <AbstractFile> getChildren24 { return (4) ; }
}
public class Client{
public static void main(String[]args) {
//構(gòu)造一個樹形的文件/目錄結(jié)構(gòu)
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);
//打印目錄文件樹
printTree(rootFolder);
}
private static void printTree(AbstractFile ifile) {
ifile.printName24;
List<AbstractFile>children=ifile.getChildren24;
if(children==null) return;
for (AbstractFile file:children) {
(5) ;
}
}
}
該程序運行后輸出結(jié)果為:
C:\
composite
TestComposite.java
Windows