Java设计模式笔记之组合模式

1.前言

整体与部分可以被一致对待的问题。组合模式也叫整体与部分模式,是结构性设计模式之一,组合模式比较简单。它将一组相似的对象看作一个对象处理,并根据一个树状结构来组合对象,然后提供一个统一的方法去访问相应的对象,以此忽略掉对象与对象集合之间的差别。

2.定义

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

3.UML图


4.应用场景

表示对象的部分-整体层次结构时;从一个整体中能够独立出部分模块或功能的场景。

5.通用模式代码

//抽象根节点
public abstract class Component {
    //节点名
    protected String name;

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

    /**
     * 具体的逻辑方法由子类去实现
     */
    public abstract void doSomething();

}

//具体枝干节点
public class Composite extends Component {
    //存储节点的容器
    private List<Component> componentList = new ArrayList<>();

    /**
     *
     * @param name
     */
    public Composite(String name) {
        super(name);
    }

    @Override
    public void doSomething() {
        Log.d("zsf", "name:" + name);
        if (null != componentList){
            for(Component c :componentList){
                c.doSomething();
            }
        }
    }

    /**
     * 添加子节点
     * @param child 子节点
     */
    public void addChild(Component child){
        componentList.add(child);
    }

    /**
     * 移除子节点
     * @param child 子节点
     */
    public void removeChild(Component child){
        componentList.remove(child);
    }

    /**
     * 获取子节点
     * @param index 子节点对应的下标
     * @return 子节点
     */
    public Component getChildren(int index){
        return componentList.get(index);
    }

}


//具体叶子节点
public class Leaf extends Component {
 public Leaf(String name) { super(name); } 
 @Override 
 public void doSomething() { 
		Log.d("zsf","name:" + name); 
	}
 }

public class ClientActivity extends Activity {

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //activity_component_client没有其他东西
        setContentView(R.layout.activity_component_client);

        //构造一个根节点
        Composite root = new Composite("root");

        //构造两个枝干节点
        Composite branch1 = new Composite("branch1");
        Composite branch2 = new Composite("branch2");

        //构造两个叶子节点
        Leaf leaf1 = new Leaf("leaf1");
        Leaf leaf2 = new Leaf("leaf2");

        //将叶子节点添加到枝干节点中
        branch1.addChild(leaf1);
        branch2.addChild(leaf2);

        //将枝干节点添加到根节点中
        root.addChild(branch1);
        root.addChild(branch2);

        //执行方法
        root.doSomething();


    }
}

将Composite中的方法同样定义到了Component中去。将组合所使用的方法定义在抽象类的方式称为透明的组合模式。上一个组合模式叫安全的组合模式。透明组合模式的UML图如下:






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值