12、组合模式(Composite Pattern,不常用)

组合模式(Composite Pattern),有时又叫作部分-整体模式,它是一种将对象组合成树状的层次结构的模式,用来表示"部分-整体"的关系,使用户对单个对象和组合对象具有一致的访问性。

它在我们树型结构的问题中,模糊了简单元素和复杂元素的概念,客户程序可以向处理简单元素一样来处理复杂元素,从而使得客户程序与复杂元素的内部结构解耦。

1)TreeNode类:

java 复制代码
package cn.jaa.composite_pattern;

import com.alibaba.fastjson2.JSON;
import lombok.Data;

import java.util.ArrayList;
import java.util.List;

/**
 * @Author: Jaa
 * @Description: 组合模式(不常用)
 * @Date 2023/12/1
 */
@Data
public class TreeNode {
    private String name;
    private TreeNode parent;
    private List<TreeNode> children = new ArrayList<>();

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

    public void add(TreeNode node) {
        children.add(node);
    }

    public void remove(TreeNode node) {
        children.remove(node);
    }

    @Override
    public String toString() {
        return "TreeNode{" +
                "name='" + name + '\'' +
                ", parent=" + parent +
                ", children=" + JSON.toJSONString(children) +
                '}';
    }
}

2)组合模式测试Demo:

java 复制代码
package cn.jaa.composite_pattern;

import lombok.extern.slf4j.Slf4j;

/**
 * @Author: Jaa
 * @Description:
 * @Date 2023/12/1
 */
@Slf4j
public class CompositeDemoTest {

    public static void main(String[] args) {
        TreeNode node1 = new TreeNode("root");
        TreeNode node2 = new TreeNode("ch1");

        node1.add(node2);
        log.info(node1.toString());

        node1.remove(node2);
        log.info(node1.toString());
    }
}

打印结果:

相关推荐
小程故事多_8013 小时前
从Claude Code源码中,拆解13个可直接复用的Agentic Harness设计模式(生产级实战解析)
人工智能·设计模式·智能体·claude code·harness
踩着两条虫17 小时前
VTJ 平台六大设计模式落地实战指南
开发语言·前端·人工智能·低代码·设计模式·重构·架构
石油人单挑所有19 小时前
基于多设计模式下的同步&异步日志系统测试报告
服务器·c++·vscode·设计模式
geovindu1 天前
go:Decorator Pattern
开发语言·设计模式·golang·装饰器模式
ximu_polaris1 天前
设计模式(C++)-行为型模式-观察者模式
c++·观察者模式·设计模式
Lands2 天前
推荐一下配合agent开发的工具
设计模式·agent
不才小强2 天前
行为型设计模式
设计模式
ximu_polaris2 天前
设计模式(C++)-结构型模式-享元模式
c++·设计模式·享元模式
geovindu2 天前
go: Facade Pattern
设计模式·golang·外观模式
旷世奇才李先生2 天前
React 18\+TypeScript实战: hooks封装与组件设计模式
react.js·设计模式·typescript