乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

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

       wtf_soft 2005-07-22

       

                                            

          B3) Composite(組合模式)
          定義:將對(duì)象組合成樹狀結(jié)構(gòu)來形成“部分-整體”層次。組合使得客戶端同樣地處理單個(gè)對(duì)象和組合對(duì)象。
          組合模式在dofactory中使用頻率為最高的LV5,實(shí)在是面向?qū)ο蟮囊粋€(gè)經(jīng)典的模式,而且樹狀結(jié)構(gòu)是現(xiàn)實(shí)中除了二維表格外最常用的數(shù)據(jù)結(jié)構(gòu)。舉最簡單的例子,有一大堆檔案,通常的保管方法就是按照拼音字母分類,放在不同的檔案夾中,再將所有的檔案夾放入抽屜,當(dāng)然,可能有些檔案無非分類,就不放在檔案夾中而是直接放入抽屜。如果有新的檔案A,就放入A檔案夾中,要找檔案S,就從檔案夾S中拿,而要轉(zhuǎn)移所有檔案,就轉(zhuǎn)移整個(gè)抽屜。這樣就將檔案組合成檔案夾,檔案夾與檔案再組合成抽屜,形成樹狀結(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模式來進(jìn)行對(duì)象的遍歷。還有一部分功能沒有完成,現(xiàn)在只是對(duì)組合對(duì)象的處理,而對(duì)單個(gè)對(duì)象的處理并沒有實(shí)現(xiàn),就是通過dirRoot對(duì)象刪除某個(gè)文件或者文件夾。由于這部分功能涉及后面要說的一個(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)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

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

        類似文章 更多