语言与模式-09组合模式

本文深入探讨了复合设计模式的应用,通过Java和Clojure两种语言实例展示了如何构建表示对象部分-整体层次结构的组合树,并强调了在实现中保持一致性的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

意图

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

适用性

  • 你想表示对象的部分—整体层次结构。
  • 你希望用户忽略组合对象与单个对象的不同,用户将统一地使用组合结构中的所有对象。

Java实现

public interface Node {
    void check();
    void add(Node node) throws Exception;
    void remove(Node node) throws Exception;
}
public class ParentNode implements Node {
    private List<Node> list = new ArrayList<Node>();

    public void check() {
        System.out.println("ParentNode is checked");
        for(Node n : list){
          n.check();
        }
    }

    public void add(Node node) {
        list.add(node);
    }

    public void remove(Node node) {
        list.remove(node);
    }
}
public class ChildNode implements Node {
    public void check() {
        System.out.println("ChildNode is Checked");
    }

    public void add(Node node) throws Exception {
        throw new Exception("This node can not add");
    }

    public void remove(Node node) throws Exception {
        throw new Exception("This node can not remove");
    }
}
public class Main {

    public static void main(String[] args) throws Exception {
        Node node1 = new ChildNode();
        Node node2 = new ChildNode();
        Node node3 = new ParentNode();
        node3.add(node1);
        node3.add(node2);
        node1.check();
        node2.check();
        node3.check();
    }
}

Clojure实现

实际上就是对树的操作!Clojure提供了clojure.zip,clojure.walk或者tree-seq来进行对树的操作!

操作起来也不是很方便就是了!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值