「グラフィックデザインパターンは、」この研究は、5-1複合モードノート

ディレクトリ

組み合わせモードでCompositeパターン。それはすることができ、コンテナと内容が再帰構造を作成するために、一貫性があることを確認してください

たとえば、次のファイルシステムでは、両方のフォルダの内容だけでなく、コンテナは、したがって、コンシステンシーを有する、ファイルシステムは、再帰的構造を形成します。組み合わせモードは、このような構造を作成するために使用されます。

コード

例として、ファイルシステムに次のコードは、複合モードを達成します。

UML

エントリークラス

これは、ディレクトリエントリ、ファイルとフォルダの抽出共通の属性を表します。

public abstract class Entry {
    public abstract String getName();                               
    public abstract int getSize();                                 

    public Entry add(Entry entry) throws RuntimeException {   
        throw new RuntimeException();
    }

    public void printList() {                                      
        printList("");
    }

    protected abstract void printList(String prefix);              

    public String toString() {                                      
        return getName() + " (size : " + getSize() + ")";
    }
}

ファイルの種類

これは、ファイルを表します

public class File extends Entry {
    private String name;
    private int size;
    public File(String name, int size) {
        this.name = name;
        this.size = size;
    }
    public String getName() {
        return name;
    }
    public int getSize() {
        return size;
    }
    protected void printList(String prefix) {
        System.out.println(prefix + "/" + this);
    }
}

ディレクトリクラス

フォルダを示します

public class Directory extends Entry {
    private String name;                    
    private ArrayList directory = new ArrayList();     
    public Directory(String name) {  
        this.name = name;
    }
    public String getName() {
        return name;
    }
    //获取文件夹的总大小,递归操作
    public int getSize() {
        int size = 0;
        Iterator it = directory.iterator();
        while (it.hasNext()) {
            Entry entry = (Entry)it.next();
            size += entry.getSize();
        }
        return size;
    }
    public Entry add(Entry entry) {
        directory.add(entry);
        return this;
    }
    protected void printList(String prefix) {
        System.out.println(prefix + "/" + this);
        Iterator it = directory.iterator();
        while (it.hasNext()) {
            Entry entry = (Entry)it.next();
            entry.printList(prefix + "/" + name);
        }
    }
}

主なカテゴリー

public class Main {
    public static void main(String[] args) {
        try {
            System.out.println("创建根目录");
            Directory rootdir = new Directory("root");
            Directory bindir = new Directory("bin");
            Directory tmpdir = new Directory("tmp");
            Directory usrdir = new Directory("usr");
            rootdir.add(bindir);
            rootdir.add(tmpdir);
            rootdir.add(usrdir);
            bindir.add(new File("vi", 10000));
            bindir.add(new File("latex", 20000));
            rootdir.printList();

            System.out.println("");
            System.out.println("创建用户目录");
            Directory xiaoming = new Directory("小明");
            Directory xiaohong = new Directory("小红");
            Directory xiaohua = new Directory("小花");
            usrdir.add(xiaoming);
            usrdir.add(xiaohong);
            usrdir.add(xiaohua);
            xiaoming.add(new File("diary.html", 100));
            xiaoming.add(new File("Composite.java", 200));
            xiaohua.add(new File("memo.tex", 300));
            xiaohong.add(new File("game.doc", 400));
            xiaohong.add(new File("junk.mail", 500));
            rootdir.printList();
        } catch (FileTreatmentException e) {
            e.printStackTrace();
        }
    }
}

结果
/*
创建根目录
/root (size : 30000)
/root/bin (size : 30000)
/root/bin/vi (size : 10000)
/root/bin/latex (size : 20000)
/root/tmp (size : 0)
/root/usr (size : 0)

创建用户目录
/root (size : 31500)
/root/bin (size : 30000)
/root/bin/vi (size : 10000)
/root/bin/latex (size : 20000)
/root/tmp (size : 0)
/root/usr (size : 1500)
/root/usr/小明 (size : 300)
/root/usr/小明/diary.html (size : 100)
/root/usr/小明/Composite.java (size : 200)
/root/usr/小红 (size : 900)
/root/usr/小红/game.doc (size : 400)
/root/usr/小红/junk.mail (size : 500)
/root/usr/小花 (size : 300)
/root/usr/小花/memo.tex (size : 300)
*/

役割

コンポーネント:リーフおよびコンポジットは、親の役割では、2つの役割を持っている一貫性のある情報が含まれています。この場合、エントリがこの役割を果たしています。

リーフ:他のオブジェクトに入れることができないコンテンツの役割を表します。ファイルのことで、この場合には、この役割を再生します。

複合材料:葉又は複合ロールを配置することができる容器の役割を表します。ディレクトリによって、この場合には、この役割を再生します。

クライアント:使用コンポジットロールモデル、メインでプレイし、この場合には

UML

考え

このモードでは、再帰のアイデアを具現化する非常にされています。コンポジット継承とコンポーネントの組み合わせ、良い味。

おすすめ

転載: www.cnblogs.com/qianbixin/p/10992961.html