zoukankan      html  css  js  c++  java
  • 设计模式(组合模式)

    组合模式是为了解决业务中“局部-整体”的关系,这里的局部整体互相嵌套,且具备相同的处理接口。

    典型的角色是两个:

    • component:包含自身抽象列表的类,下例中为Employee;
    • composite:各个组成部分对外暴露的处理接口,下例中为toString,为单独抽象;

    代码如下:

    • Employee
    package com.example;
    
    import java.util.ArrayList;
    import java.util.Iterator;
    import java.util.List;
    
    public class Employee {
    
        private String name;
        private String deptname;
        private List<Employee> subs;
        
        public Employee(String name, String deptname){
            this.name = name;
            this.deptname = deptname;
            subs = new ArrayList<Employee>();        
        }
    
        public void add(Employee e) {
            subs.add(e);
        }
    
        public void remove(Employee e) {
            for (Iterator<Employee> it = subs.iterator(); it.hasNext();) {
                if (((Employee) it.next()).name == e.name) {
                    it.remove();
                }
            }
        }
        
        //这里的toString,等价于于composite方法
        public String toString() {
            return ("Employee :[ Name : " + name + ", dept : " + deptname + " ]");
        }
    
        public List<Employee> getSubs() {
            return subs;
        }
    
    }
    • App 测试类
    public class App {
    
        public static void main(String[] args) {
            Employee e1 = new Employee("fredric", "dept1");
            Employee e2 = new Employee("sinny", "dept2");
            Employee e3 = new Employee("baobao", "dept2");
            e1.add(e2);
            e1.add(e3);
            for(Employee emp:e1.getSubs()){
                System.out.println(emp);
            }
            e1.remove(e2);
            for(Employee emp:e1.getSubs()){
                System.out.println(emp);
            }        
        }
    }
  • 相关阅读:
    Silverlight Toolkit ListBoxDragDropTarget学习笔记
    函数指针和指针函数(转)
    面试题_反转链表
    C++中的异或运算符^
    面试题_旋转字符串
    面试题_寻找丑数
    模拟一个简单的基于tcp的远程关机程序
    管理指针成员
    赫夫曼树编码问题
    堆的基本操作
  • 原文地址:https://www.cnblogs.com/Fredric-2013/p/4571991.html
Copyright © 2011-2022 走看看