小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

GoF設(shè)計(jì)模式之八 Composite- -

 wtf_soft 2005-07-22

 

                                      

    B3) Composite(組合模式)
    定義:將對(duì)象組合成樹(shù)狀結(jié)構(gòu)來(lái)形成“部分-整體”層次。組合使得客戶端同樣地處理單個(gè)對(duì)象和組合對(duì)象。
    組合模式在dofactory中使用頻率為最高的LV5,實(shí)在是面向?qū)ο蟮囊粋€(gè)經(jīng)典的模式,而且樹(shù)狀結(jié)構(gòu)是現(xiàn)實(shí)中除了二維表格外最常用的數(shù)據(jù)結(jié)構(gòu)。舉最簡(jiǎn)單的例子,有一大堆檔案,通常的保管方法就是按照拼音字母分類,放在不同的檔案夾中,再將所有的檔案夾放入抽屜,當(dāng)然,可能有些檔案無(wú)非分類,就不放在檔案夾中而是直接放入抽屜。如果有新的檔案A,就放入A檔案夾中,要找檔案S,就從檔案夾S中拿,而要轉(zhuǎn)移所有檔案,就轉(zhuǎn)移整個(gè)抽屜。這樣就將檔案組合成檔案夾,檔案夾與檔案再組合成抽屜,形成樹(shù)狀結(jié)構(gòu)。電腦中存放文件(file)的方式也是如此,現(xiàn)在只考慮對(duì)文件的刪除。文件對(duì)象如下表示:
    public interface FileEntry {
        public void remove();
    }
    public File implements FileEntry {
        private String name;
        public File(String name) {
            this.name = name;
        }
        public void remove() {
            System.out.println("File " + name + " has been deleted.");
        }
    }

    文件目錄(文件夾)對(duì)象
    public Dir implements FileEntry {
        private List files;
        private String name;
        public Dir(String name) {
            this.name = name;
            this.files = new ArrayList();
        }
        public void add(FileEntry fileEntry) {
            files.add(fileEntry);
        }
        public void remove() {
            Iterator itr = files.iterator();
            While (itr.hasNext()) {
                FileEntry fileEntry = (FileEntry)itr.next();
                fileEntry.remove();
            }
            System.out.println("Dir " + name + " has been deleted.");
        }
    }

    對(duì)于文件夾的操作
    Dir dirRoot = new Dir("root");
    Dir dirSub = new Dir("sub");
    File fileA = new File("A.file");
    File fileB = new File("B.file");
    File fileX = new File("X.file");
    File file1 = new File("1.file");
    dirSub.add(fileA);
    dirSub.add(fileB);
    dirSub.add(fileX);
    dirRoot.add(dirSub);
    dirRoot.add(file1);
    //delete
    dirRoot.remove();

    這樣,所有的文件和文件夾都會(huì)被刪除,這里面還用到了以前提到的Iterator模式來(lái)進(jìn)行對(duì)象的遍歷。還有一部分功能沒(méi)有完成,現(xiàn)在只是對(duì)組合對(duì)象的處理,而對(duì)單個(gè)對(duì)象的處理并沒(méi)有實(shí)現(xiàn),就是通過(guò)dirRoot對(duì)象刪除某個(gè)文件或者文件夾。由于這部分功能涉及后面要說(shuō)的一個(gè)模式Chain Of Responsibility(職責(zé)鏈),暫時(shí)不提以免混淆,而功能將會(huì)在以后講COR的時(shí)候補(bǔ)充完整。


   參考:
1、 http://www./designpatterns/composite.htm(中文、java實(shí)例)
2、 http://www./Patterns/PatternComposite.aspx(英文、C#實(shí)例、UML)
3、 http://www./tech/DesignPattern/Composite.html(日文、java實(shí)例、UML)推薦

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多