组合模式

组合模式:将对象组合成树形结构以表示“部分-整体”的层次结构。组合模式使得用户对单个对象和组合对象的使用具有一致性。

即整体与部分可以被一致对待,我们就声明一个接口,其中包括所有管理子对象的方法。枝节点维护一个List的Add和Remove方法,叶节点的Add和Remove没有意义。

看Component接口:

public abstract class Component {
    protected String name;

    public Component(String name) {
        this.name = name;
    }

    public abstract void add(Component c);
    public abstract void remove(Component c);
    public abstract void display(int depth);
}

来看枝节点

public class Composite extends Component {
    private List<Component> children = new ArrayList<Component>();

    public Composite(String name) {
        super(name);
    }

    @Override
    public void add(Component c) {
        children.add(c);
    }

    @Override
    public void remove(Component c) {
        children.remove(c);
    }

    @Override
    public void display(int depth) {
        for (int j = 0 ; j < depth; j++) {
            System.out.print("-");
        }
        System.out.println(name);
        for (Component c : children) {
            c.display(depth + 2);
        }
    }
}

枝节点维护List的增删,并且遍历调用所有子对象的接口方法。

public class Leaf extends Component {
    public Leaf(String name) {
        super(name);
    }

    @Override
    public void display(int depth) {
        for(int i = 0; i < depth; i++) {
            System.out.print("-");
        }
        System.out.println(name);
    }

    @Override
    public void remove(Component c) {

    }

    @Override
    public void add(Component c) {

    }
}

叶节点的Add和Remove方法没有实际意义。

主函数代码:

Composite root = new Composite("root");
root.add(new Leaf("Leaf A"));
root.add(new Leaf("Leaf B"));

Composite comp = new Composite("Composite x");
comp.add(new Leaf("Leaf xA"));
comp.add(new Leaf("Leaf xB"));

root.add(comp);

Composite comp2 = new Composite("Composite xy");
comp2.add(new Leaf("Leaf XYA"));
comp2.add(new Leaf("Leaf XYB"));

comp.add(comp2);

root.add(new Leaf("Leaf C"));

Leaf leaf = new Leaf("Leaf D");

root.add(leaf);
root.remove(leaf);

root.display(1);

结果:

-root
---Leaf A
---Leaf B
---Composite x
-----Leaf xA
-----Leaf xB
-----Composite xy
-------Leaf XYA
-------Leaf XYB
---Leaf C

比如说一些科技公司,它们的深圳总部有所有产品线和管理、运营部门,但是各省市分公司的部门相对不那么完整,但是基本职能都一样,这时就对应上组合模式了。每个分公司为枝叶,每个部门为子叶,各省市就如总公司的枝叶节点一样,总公司也有自己的子叶节点。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值