23种设计模式_MODE11组合模式_手写代码实现

简介: 23种设计模式_MODE11组合模式_手写代码实现

1.组合模式 || 整体部分模式 --测试

package com.zhaoshuangjian.mode11_组合模式;
import com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode;
import com.zhaoshuangjian.mode11_组合模式.mode11.login.LoginDiagram;
/**
 * <p>组合模式 || 整体部分模式 --测试</p>
 * 组合模式(Composite Pattern),又叫部分整体模式,
 * 是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,
 * 用来表示部分以及整体层次。这种类型的设计模式属于结构型模式,它创建了对象组的树形结构。
 * 这种模式创建了一个包含自己对象组的类。该类提供了修改相同对象组的方式。
 *
 * @Author zhaoshuangjian  2023-03-25 下午21:44
 */
public class CompositeTest {
    public static void paintDiagram(){
        System.out.println("============开始============");
        System.out.println("           /    \\");
        System.out.println("        登录   退出");
        System.out.println("        /  \\   ");
        System.out.println("     首页  失败   ");
        System.out.println("     /  \\   ");
        System.out.println("商品中心 用户中心   ");
        System.out.println("============================");
    }
    public static void main(String[] args) {
        // 登录流程图
        paintDiagram();
        LoginDiagram loginUML = new LoginDiagram("开始");
        // 拿到根节点
        TreeNode root = loginUML.getRoot();
        // 添加一级子节点
        TreeNode loginNode = root.addChildren("登录");
        TreeNode exitNode  = root.addChildren("退出");
        // 添加二级子节点
        TreeNode homeNode = loginNode.addChildren("首页");
        loginNode.addChildren("失败");
        // 添加三级子节点
        homeNode.addChildren("商品中心");
        homeNode.addChildren("用户中心");
        // 遍历登录流程树状结构
        loginUML.traverse(root);
    }
}

2.树

package com.zhaoshuangjian.mode11_组合模式.mode11;
/**
 * <p>树</p>
 *
 * @Author zhaoshuangjian  2023-03-25 下午21:44
 */
public abstract class AbstractTree {
    private com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode root = null;
    public AbstractTree(){
    }
    public com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode getRoot() {
        return root;
    }
    public AbstractTree(String name){
        root = new com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode(name);
    }
    /**
     * 抽象方法 == 树节点遍历,由具体的子类实现
     */
    public abstract void traverse(com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode node);
}

3.树节点

package com.zhaoshuangjian.mode11_组合模式.mode11;
import java.util.ArrayList;
import java.util.List;
/**
 * <p>树节点</p>
 *
 * @Author zhaoshuangjian  2023-03-25 下午21:44
 */
public class TreeNode {
    /**
     * 节点名称
     */
    private String name;
    /**
     * 节点的父节点
     */
    private com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode parent;
    /**
     * 节点的子节点
     */
    private List<TreeNode> childrens = new ArrayList<>();
    public TreeNode(){}
    public TreeNode(String name){
        this.name = name;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode getParent() {
        return parent;
    }
    public void setParent(com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode parent) {
        this.parent = parent;
    }
    public List<TreeNode> getChildrens() {
        return childrens;
    }
    public void setChildrens(List<TreeNode> childrens) {
        this.childrens = childrens;
    }
    public void addChildren(com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode node){
        // 别忘设置节点的父
        node.setParent(this);
        this.childrens.add(node);
    }
    public com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode addChildren(String node){
        com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode cNode = new com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode(node);
        // 别忘设置节点的父
        cNode.setParent(this);
        this.childrens.add(cNode);
        return cNode;
    }
    public void removeChildren(com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode node){
        this.childrens.remove(node);
    }
    /**
     * 是否是叶子
     */
    public boolean isLeaf(){
         return  !(this.childrens.size()>0) && (this.parent != null);
    }
    /**
     * 是否有父节点 == 如果没有,就是根节点
     * @return
     */
    public boolean hasParent(){return !(this.parent == null);}
    /**
     * 根节点没有父节点
     * @return
     */
    public boolean isRoot(){return  this.parent == null;}
}

4.登录流程图 == 继承抽象树结构


package com.zhaoshuangjian.mode11_组合模式.mode11.login;
import com.zhaoshuangjian.mode11_组合模式.mode11.AbstractTree;
import com.zhaoshuangjian.mode11_组合模式.mode11.TreeNode;
import java.util.List;
/**
 * <p>登录流程图 == 继承抽象树结构</p>
 *
 * @Author zhaoshuangjian  2023-03-25 下午21:44
 */
public class LoginDiagram extends AbstractTree {
    public LoginDiagram(String name){
        super(name);
    }
    @Override
    public void traverse(TreeNode node) {
        if(node.isRoot()){
            System.out.println("根:"+node.getName()+",父节点:"+node.getParent());
        }else if(node.isLeaf()){
            System.out.println("叶子:"+node.getName()+",父节点:"+node.getParent().getName());
        }else{
            System.out.println("枝:"+node.getName()+",父节点:"+node.getParent().getName());
        }
        // 递归遍历
        List<TreeNode> childrens = node.getChildrens();
        for (TreeNode cNode : childrens) {
            traverse(cNode) ;
        }
    }
}
相关文章
|
1月前
|
设计模式 存储 安全
「全网最细 + 实战源码案例」设计模式——组合模式
组合模式(Composite Pattern)是一种结构型设计模式,用于将对象组合成树形结构以表示“部分-整体”的层次结构。它允许客户端以一致的方式对待单个对象和对象集合,简化了复杂结构的处理。组合模式包含三个主要组件:抽象组件(Component)、叶子节点(Leaf)和组合节点(Composite)。通过这种模式,客户端可以统一处理简单元素和复杂元素,而无需关心其内部结构。适用于需要实现树状对象结构或希望以相同方式处理简单和复杂元素的场景。优点包括支持树形结构、透明性和遵循开闭原则;缺点是可能引入不必要的复杂性和过度抽象。
85 22
|
6月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。
|
6月前
|
设计模式 算法 数据库连接
PHP中的设计模式:提高代码的可维护性与扩展性本文旨在探讨PHP中常见的设计模式及其应用,帮助开发者编写出更加灵活、可维护和易于扩展的代码。通过深入浅出的解释和实例演示,我们将了解如何使用设计模式解决实际开发中的问题,并提升代码质量。
在软件开发过程中,设计模式是一套经过验证的解决方案模板,用于处理常见的软件设计问题。PHP作为流行的服务器端脚本语言,也有其特定的设计模式应用。本文将重点介绍几种PHP中常用的设计模式,包括单例模式、工厂模式和策略模式,并通过实际代码示例展示它们的具体用法。同时,我们还将讨论如何在实际项目中合理选择和应用这些设计模式,以提升代码的可维护性和扩展性。
117 4
|
5月前
|
设计模式 算法 数据库连接
PHP中的设计模式:提高代码的可维护性和扩展性
【10月更文挑战第13天】 本文将探讨PHP中常见的设计模式及其在实际项目中的应用。通过对比传统编程方式,我们将展示设计模式如何有效地提高代码的可维护性和扩展性。无论是单例模式确保类的单一实例,还是观察者模式实现对象间的松耦合,每一种设计模式都为开发者提供了解决特定问题的最佳实践。阅读本文后,读者将能更好地理解和应用这些设计模式,从而提升PHP编程的效率和质量。
|
6月前
|
设计模式 算法 搜索推荐
PHP中的设计模式:提高代码可维护性的秘诀
在本文中,我们将探讨PHP设计模式的重要性以及它们如何帮助开发者编写出更加灵活、可维护的代码。我们将介绍几种常见的设计模式,包括单例模式、工厂模式和策略模式,并通过实际示例展示它们在PHP中的应用。最后,我们会讨论何时使用这些设计模式以及在实际项目开发中的最佳实践。
86 22
|
6月前
|
设计模式 Java
Java设计模式:组合模式的介绍及代码演示
组合模式是一种结构型设计模式,用于将多个对象组织成树形结构,并统一处理所有对象。例如,统计公司总人数时,可先统计各部门人数再求和。该模式包括一个通用接口、表示节点的类及其实现类。通过树形结构和节点的通用方法,组合模式使程序更易扩展和维护。
Java设计模式:组合模式的介绍及代码演示
|
5月前
|
设计模式 SQL 安全
PHP中的设计模式:单例模式的深入探索与实践在PHP开发领域,设计模式是解决常见问题的高效方案集合。它们不是具体的代码,而是一种编码和设计经验的总结。单例模式作为设计模式中的一种,确保了一个类仅有一个实例,并提供一个全局访问点。本文将深入探讨单例模式的基本概念、实现方式及其在PHP中的应用。
单例模式在PHP中的应用广泛,尤其在处理数据库连接、日志记录等场景时,能显著提高资源利用率和执行效率。本文从单例模式的定义出发,详细解释了其在PHP中的不同实现方法,并探讨了使用单例模式的优势与注意事项。通过对示例代码的分析,读者将能够理解如何在PHP项目中有效应用单例模式。
|
6月前
|
设计模式 算法 数据库连接
PHP中的设计模式:提高代码的可维护性与扩展性
设计模式在PHP开发中至关重要,如单例模式确保类仅有一个实例并提供全局访问点,适用于管理数据库连接或日志记录。工厂模式封装对象创建过程,降低系统耦合度;策略模式定义算法系列并使其可互换,便于实现不同算法间的切换。合理选择设计模式需基于需求分析,考虑系统架构,并通过测试驱动开发验证有效性,确保团队协作一致性和代码持续优化。设计模式能显著提升代码质量,解决开发中的设计难题。
52 8
|
6月前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的深入探索与实践在软件开发的广袤天地中,PHP以其独特的魅力和强大的功能,成为无数开发者手中的得力工具。而在这条充满挑战与机遇的征途上,设计模式犹如一盏明灯,指引着我们穿越代码的迷雾,编写出更加高效、灵活且易于维护的程序。今天,就让我们聚焦于设计模式中的璀璨明珠——策略模式,深入探讨其在PHP中的实现方法及其实际应用价值。
策略模式,这一设计模式的核心在于它为软件设计带来了一种全新的视角和方法。它允许我们在运行时根据不同情况选择最适合的解决方案,从而极大地提高了程序的灵活性和可扩展性。在PHP这门广泛应用的编程语言中,策略模式同样大放异彩,为开发者们提供了丰富的创作空间。本文将从策略模式的基本概念入手,逐步深入到PHP中的实现细节,并通过一个具体的实例来展示其在实际项目中的应用效果。我们还将探讨策略模式的优势以及在实际应用中可能遇到的挑战和解决方案,为PHP开发者提供一份宝贵的参考。
|
6月前
|
设计模式 算法 PHP
PHP中的设计模式:提升代码的灵活性与可维护性
在本文中,我们将深入探讨PHP编程语言中的一种重要概念——设计模式。设计模式是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。它代表了最佳的实践,被有经验的面向对象的软件开发人员所采用。本文将通过具体的实例,展示如何在PHP项目中应用设计模式,以提高代码的灵活性和可维护性。无论你是PHP初学者还是经验丰富的开发者,都能从中获得有价值的见解。