Java设计模式的组合模式如何实现

本篇内容主要讲解“Java设计模式的组合模式如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java设计模式的组合模式如何实现”吧!

成都创新互联是由多位在大型网络公司、广告设计公司的优秀设计人员和策划人员组成的一个具有丰富经验的团队,其中包括网站策划、网页美工、网站程序员、网页设计师、平面广告设计师、网络营销人员及形象策划。承接:做网站、成都网站制作、网站改版、网页设计制作、网站建设与维护、网络推广、数据库开发,以高性价比制作企业网站、行业门户平台等全方位的服务。

组合模式

组合模式(Composite Pattern) ,又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,用来表示部分以及整体层次。这种类型的设计模式属于结构型模式,它创建了对象组的树形结构。

这种模式创建了一个包含自己对象组的类。该类提供了修改相同对象组的方式。

我们通过下面的实例来演示组合模式的用法。实例演示了一个组织中员工的层次结构。

介绍

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

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

何时使用:

1.您想表示对象的部分-整体层次结构(树形结构)。

⒉您希望用户忽略组合对象与单个对象的不同,用户将统一地使用组合结构中的所有对象。

如何解决:树枝和叶子实现统一接口,树枝内部组含该接口。

关键代码:树枝内部组合该接口,并且含有内部属性List,里面放Component。

应用实例:
1.算术表达式包括操作数、操作符和另一个操作数,其中另一个操作符也可以是操作数、操作符和另一个操作数。

2.在JAVAAWT和Swing中,对于Button和Checkbox是树叶,Container是树枝。

优点:

1.高层模块调用简单。

2.节点自由增加。

缺点:在使用组合模式时,其叶子和树枝的声明都是实现类,而不是接口,违反了依赖倒置原则。

使用场景:部分、整体场景,如树形菜单,文件、文件夹的管理。

注意事项:定义时为具体类。

实现

创建一个Employee类,该类被当作组合模型类。CompositePatternDemo类使用Employee类来添加部门层次结构,并打印所有员工。

Java设计模式的组合模式如何实现

1.创建一个项目名称为composite_pattern的Java项目。

2.创建Employee类,该类带有Employee对象的列表。

package com.js;

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

public class Employee {
    //姓名
    private String name;
    //部门
    private String dept;
    //薪水
    private int salary;
    //List集合存储当前员工的下属
    private List subordinate;

    //构造方法完成员工信息的初始化操作
    public Employee(String name, String dept, int salary) {
        this.name = name;
        this.dept = dept;
        this.salary = salary;
        //重构:用来维护当前员工是否有下属的一个属性   
        this.subordinate = new ArrayList<>();
    }

    public void add(Employee employee){
        subordinate.add(employee);
    }

    public void remove(Employee employee){
        subordinate.remove(employee);
    }

    public List getSubordinate(){
        return subordinate;
    }

    @Override
    public String toString() {
        return "Employee{" +
                "name='" + name + '\'' +
                ", dept='" + dept + '\'' +
                ", salary=" + salary +
                ", subordinate=" + subordinate +
                '}';
    }
}

2.编写程序入口

package com.js;

public class CompositePattern {
    public static void main(String[] args) {
        //CEO
        Employee employee=new Employee("张三","CEO",3000000);
        //法定代表人
        Employee emp1=new Employee("李四","法务部",10000);
        //市场总监
        Employee emp2=new Employee("王五","市场总监",20000);
        employee.add(emp1);
        employee.add(emp2);

        Employee emp3=new Employee("小明","市场部",5000);
        Employee emp4=new Employee("小红","市场部",5000);
        emp2.add(emp3);
        emp2.add(emp4);
        
        //输出当前的员工的树形结构
        System.out.println(employee);

        for (Employee e:employee.getSubordinate()) {
            System.out.println(e);
            for (Employee emp:e.getSubordinate()) {
                System.out.println(emp);
            }
        }
    }
}

3.结果

Employee{name='张三', dept='CEO', salary=3000000, subordinate=[Employee{name='李四', dept='法务部', salary=10000, subordinate=[]}, Employee{name='王五', dept='市场总监', salary=20000, subordinate=[Employee{name='小明', dept='市场部', salary=5000, subordinate=[]}, Employee{name='小红', dept='市场部', salary=5000, subordinate=[]}]}]}
Employee{name='李四', dept='法务部', salary=10000, subordinate=[]}
Employee{name='王五', dept='市场总监', salary=20000, subordinate=[Employee{name='小明', dept='市场部', salary=5000, subordinate=[]}, Employee{name='小红', dept='市场部', salary=5000, subordinate=[]}]}
Employee{name='小明', dept='市场部', salary=5000, subordinate=[]}
Employee{name='小红', dept='市场部', salary=5000, subordinate=[]}

到此,相信大家对“Java设计模式的组合模式如何实现”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


文章题目:Java设计模式的组合模式如何实现
文章位置:http://bzwzjz.com/article/gissop.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 网站建设方案 公司网站建设 定制网站建设多少钱 手机网站建设套餐 高端网站设计 成都网站建设 成都网站建设 专业网站设计 古蔺网站建设 四川成都网站设计 网站建设开发 营销网站建设 成都网站建设 高端网站设计 网站建设公司 四川成都网站建设 成都网站制作 重庆电商网站建设 成都网站建设 广安网站设计 攀枝花网站设计 重庆网站设计