Android设计模式-组合模式

2019-10-25  本文已影响0人  星宇V

UML关系简单介绍
UML简单使用的介绍
创建型设计模式
Android设计模式-单例模式
Android设计模式-工厂模式
Android设计模式-抽象工厂模式
Android设计模式-建造者模式
Android设计模式-原型模式
结构型设计模式
Android设计模式-代理模式
Android设计模式-装饰模式
Android设计模式-适配器模式
Android设计模式-组合模式
Android设计模式-门面模式
Android设计模式-桥接模式
Android设计模式-享元模式
行为型设计模式
Android设计模式-策略模式
Android设计模式-命令模式
Android设计模式-责任链模式
Android设计模式-模版方法模式
Android设计模式-迭代器模式
Android设计模式-观察者模式
Android设计模式-备忘录模式
Android设计模式-中介者模式
Android设计模式-访问者模式
Android设计模式-状态模式
Android设计模式-解释器模式

1.定义

将对象组合成树形结构以表示“部分-整体”的层次结构,使得用户对单个对象和组合对象的使用具有一致性。
组合模式也叫合同模式,有时也叫部分-整体模式,主要是用来描述部分与整体的关系

2.组合模式UML

组合模式分为透明组合模式和安全组合模式

2.1透明组合模式UML

透明组合模式

2.2安全组合模式UML

安全组合模式

2.3区别

从图中可以明显看出来,透明组合模式与安全组合模式的区别
主要在于抽象类与树枝类的区别,透明组合模式的一些相关操作,都在抽象类中,而安全组合模式,关于组合使用的方法放到了具体的实现类中。

2.4角色介绍

3.简单实现

3.1透明组合模式

3.1.1 抽象构件

public abstract class Component {
    public ArrayList<Component> componentList=new ArrayList<>();
    public void doSomething(){

    }
    public abstract void add(Component compoment);

    public abstract void remove(Compoment compoment);

    public abstract ArrayList<Component> getChildren();
}

3.1.2 叶子构件

public class Leaf extends Component {
    @Deprecated
    @Override
    public void add(Component compoment) throws UnsupportedOperationException{
        throw new UnsupportedOperationException();
    }

    @Deprecated
    @Override
    public void remove(Compoment compoment) throws UnsupportedOperationException{
        throw new UnsupportedOperationException();
    }
    @Deprecated
    @Override
    public ArrayList<Component> getChildren() throws UnsupportedOperationException{
        throw new UnsupportedOperationException();
    }
}

添加Deprecated注解,可在对象调用方法的时候,发现是过期方法。

3.1.3 树枝构件

public class Composite extends Component {
    @Override
    public void add(Component compoment) {
        this.componentList.add(compoment);
    }

    @Override
    public void remove(Compoment compoment) {
        this.componentList.remove(compoment);
    }

    @Override
    public ArrayList<Component> getChildren() {
        return this.componentList;
    }
}

3.1.4 客户端调用

public class MyClass {
    public static void main(String args[]) {
//空数据。。。假装有数据。。。
        Component root=new Composite();
        traverse(root);
    }
//通过递归进行遍历(结果就不打印了,,毕竟是空数据。。)
    private static void traverse(Component root) {
        for(Component component:root.getChildren()){
            if (component instanceof Leaf){
                component.doSomething();
            }else {
                traverse(component);
            }
        }
    }
}

3.2 安全组合模式

相比于透明组合模式,两者的区别,就是一个将相关的操作放在了抽象类中,另一个将相关的操作放在了具体的类中。

3.2.1 抽象构件

public abstract class Component {
    public void doSomething(){

    }

}

3.2.2 叶子构件

public class Leaf extends Component {
    @Override
    public void doSomething() {
        //自己想加啥加啥。。。
    }
}

3.2.3 树枝构件

public class Composite extends Component {
    private ArrayList<Component> componentList=new ArrayList<>();
    public void add(Component compoment) {
        this.componentList.add(compoment);
    }

    public void remove(Compoment compoment) {
        this.componentList.remove(compoment);
    }

    public ArrayList<Component> getChildren() {
        return this.componentList;
    }
}

3.2.4 场景调用

public class MyClass {
    public static void main(String args[]) {
        Component root=new Composite();
        traverse((Composite) root);
    }

    private static void traverse(Composite root) {
        for(Component component:root.getChildren()){
            if (component instanceof Leaf){
                component.doSomething();
            }else {
                traverse((Composite) component);
            }
        }
    }
}

相比于透明组合模式,安全组合模式在进行递归的时候需要进行强转操作,毕竟相关的方法是在具体子类进行实现的而不是在抽象类中。同样因为是空数据。。。就不打印了。

4.总结

4.1优点

4.2使用场景

上一篇下一篇

猜你喜欢

热点阅读