`

设计模式----组合模式(composite)

 
阅读更多
该设计模式是以公司的组织结构为背景的

Crop.java代码如下:

package com.designPattern.composite;

public abstract class Corp {

	private String name ="";
	
	private String position = "";
	
	private int salary = 0;
	
	public Corp(String name,String position,int salary){
		this.name = name;
		this.position = position;
		this.salary = salary;
	}
	
	public String getInfo(){
		String info = "姓名:"+this.name+"\t职位:"+this.position+"\t薪水:"+this.salary;
		return info;
	}
}



Leaf.java代码如下:

package com.designPattern.composite;

public class Leaf extends Corp{

	public Leaf(String name, String position, int salary) {
		super(name, position, salary);
	}

}



Branch.java代码如下:
 package com.designPattern.composite;

import java.util.ArrayList;

public class Branch extends Corp{
	ArrayList<Corp> subordinateList = new ArrayList<Corp>();

	public Branch(String name, String position, int salary) {
		super(name, position, salary);
	}
	
	public void addSubordinate(Corp corp){
		this.subordinateList.add(corp);
	}
	
	public ArrayList<Corp> getSubordinate(){
		return this.subordinateList;
	}

}



Client.java代码如下:
 package com.designPattern.composite;

import java.util.ArrayList;

public class Client {
	
	public static void main(String[] args) {
		Branch ceo = compositeTree();
		System.out.println(ceo.getInfo());
		
		System.out.println(getTreeInfo(ceo));
	}
	
	public static Branch compositeTree(){
		Branch root = new Branch("老大","总经理",100000);
		
		Branch developDep = new Branch("老刘","研发部经理",10000);
		Branch salesDep = new Branch("老马","销售部经理",20000);
		Branch financeDep = new Branch("老赵","财务部经理",30000);
		
		Branch firstDevGroup = new Branch("杨组长","研发一组组长",8000);
		Branch secondDevGroup = new Branch("吴组长","研发二组组长",8000);
		
		Leaf a = new Leaf("a","开发人员",2000);
		Leaf b = new Leaf("b","开发人员",2000);
		Leaf c = new Leaf("c","开发人员",2000);
		Leaf d = new Leaf("d","开发人员",2000);
		Leaf e = new Leaf("e","开发人员",2000);
		Leaf f = new Leaf("f","开发人员",2000);
		Leaf g = new Leaf("g","开发人员",2000);
		Leaf h = new Leaf("h","开发人员",2000);
		Leaf i = new Leaf("i","开发人员",2000);
		Leaf k = new Leaf("k","销售人员",2000);
		Leaf l = new Leaf("l","销售人员",2000);
		Leaf j = new Leaf("j","财务人员",2000);
		Leaf m = new Leaf("m","财务人员",2000);
		Leaf n = new Leaf("n","CEO秘书",2000);
		Leaf p = new Leaf("陆副经理","研发部副经理",2000);
		
		firstDevGroup.addSubordinate(a);
		firstDevGroup.addSubordinate(b);
		firstDevGroup.addSubordinate(c);
		firstDevGroup.addSubordinate(d);
		
		secondDevGroup.addSubordinate(e);
		secondDevGroup.addSubordinate(f);
		secondDevGroup.addSubordinate(g);
		secondDevGroup.addSubordinate(h);
		secondDevGroup.addSubordinate(i);
		
		salesDep.addSubordinate(k);
		salesDep.addSubordinate(l);
		
		financeDep.addSubordinate(j);
		financeDep.addSubordinate(m);
	
		developDep.addSubordinate(firstDevGroup);
		developDep.addSubordinate(secondDevGroup);
		developDep.addSubordinate(p);
		
		root.addSubordinate(n);
		root.addSubordinate(salesDep);
		root.addSubordinate(financeDep);
		root.addSubordinate(developDep);
		
		return root;
		
	}
	
	public static String getTreeInfo(Branch root){
		ArrayList<Corp> subordinateList = root.getSubordinate();
		String info = "";
		
		for(Corp c:subordinateList){
			if(c instanceof Leaf){
				info = info +c.getInfo()+"\n";
			}else{
				info = info +c.getInfo()+"\n"+getTreeInfo((Branch)c);
			}
		}
		
		return info;
	}

}



运行结果如下:
 姓名:老大	职位:总经理	薪水:100000
姓名:n	职位:CEO秘书	薪水:2000
姓名:老马	职位:销售部经理	薪水:20000
姓名:k	职位:销售人员	薪水:2000
姓名:l	职位:销售人员	薪水:2000
姓名:老赵	职位:财务部经理	薪水:30000
姓名:j	职位:财务人员	薪水:2000
姓名:m	职位:财务人员	薪水:2000
姓名:老刘	职位:研发部经理	薪水:10000
姓名:杨组长	职位:研发一组组长	薪水:8000
姓名:a	职位:开发人员	薪水:2000
姓名:b	职位:开发人员	薪水:2000
姓名:c	职位:开发人员	薪水:2000
姓名:d	职位:开发人员	薪水:2000
姓名:吴组长	职位:研发二组组长	薪水:8000
姓名:e	职位:开发人员	薪水:2000
姓名:f	职位:开发人员	薪水:2000
姓名:g	职位:开发人员	薪水:2000
姓名:h	职位:开发人员	薪水:2000
姓名:i	职位:开发人员	薪水:2000
姓名:陆副经理	职位:研发部副经理	薪水:2000
分享到:
评论

相关推荐

    c++设计模式-结构型模式-组合模式

    c++设计模式-结构型模式-组合模式;qt工程;c++简单源码; 组合(Composite Pattern)模式的定义:有时又叫作整体-部分(Part-Whole)模式,它是一种将对象组合成树状的层次结构的模式,用来表示“整体-部分”的关系...

    设计模式之组合模式(Composite Pattern)

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

    设计模式--C++

    2.2.3 组合模式 272.3 格式化 27 2.3.1 封装格式化算法 27 2.3.2 Compositor 和 Composition 27 2.3.3 策略模式 29 2.4 修饰用户界面 29 2.4.1 透明围栏 29 2.4.2 Monoglyph 30 2.4.3 Decorator 模式 32 2.5 支持...

    JAVA设计模式-day2.pdf

    JAVA设计模式-day2,请的行业大能讲得课程,涉及:创建模式(5种: 1、 工厂方法模式(Factory Method);... 11、 组合模式(Composite))、关系模式(11种),挺不错的,或许对某些专业技术人事有帮组,推荐给大家。

    C++设计模式课件20_Composite_组合模式.pdf

    C++设计模式课件20_Composite_组合模式.pdf

    设计模式C++学习之组合模式(Composite)

    设计模式C++学习之组合模式(Composite)

    设计模式_组合模式.zip

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

    研磨设计模式-part2

    第15章 组合模式(Composite) 第16章 模板方法模式(Template Method) 第17章 策略模式(Strategy) 第18章 状态模式(State) 第19章 备忘录模式(Memento) 第20章 享元模式(Flyweight) 第21章 解释器模式...

    研磨设计模式-part4

    第15章 组合模式(Composite) 第16章 模板方法模式(Template Method) 第17章 策略模式(Strategy) 第18章 状态模式(State) 第19章 备忘录模式(Memento) 第20章 享元模式(Flyweight) 第21章 解释器模式...

    研磨设计模式-part3

    第15章 组合模式(Composite) 第16章 模板方法模式(Template Method) 第17章 策略模式(Strategy) 第18章 状态模式(State) 第19章 备忘录模式(Memento) 第20章 享元模式(Flyweight) 第21章 解释器模式...

    java版本二十三种设计模式.zip

    - 组合模式(Composite) - 外观模式(Facade) - 享元模式(Flyweight) - 观察者模式(Observer) - 模板方法模式(Template Method) - 策略模式(Strategy) - 责任链模式(Chain of Responsibility) - 中介者模式...

    C#面向对象设计模式纵横谈(9):Composite 组合模式(结构型模式)

    C#面向对象设计模式纵横谈(9):Composite 组合模式(结构型模式) 体验课程

    JAVA设计模式chm文档

    设计模式之Composite(组合) 设计模式之Decorator(油漆工) 设计模式之Bridge 设计模式之Flyweight(享元) 行为模式: 设计模式之Template 设计模式之Memento(备忘机制) 设计模式之Observer 设计模式之Chain of ...

    组合模式 Composite Pattern

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

    23种设计模式 - 各种模式的学习

    23种设计模式 目录 创建型 1. Factory Method(工厂方法) 2. Abstract Factory(抽象工厂) 3. Builder(建造者) 4. Prototype(原型) 5. Singleton(单例) 结构型 6. Adapter Class/Object(适配器) ...

    设计模式面面观(10):桥接模式(Bridge Pattern)-结构型模式

    组合模式(Composite Pattern)-结构型模式 (0%) &lt;br&gt;讲义书写模式 在实际的讲解中我会用一套模式来讲述我对设计模式的理解 1.给出当前章节模式的名称 2.讲述一个小故事,提出问题 3.回答这个...

    C#面向对象设计模式纵横谈(9):Composite 组合模式(结构型模式) (Level 300)

    C#面向对象设计模式纵横谈(9):Composite 组合模式(结构型模式) (Level 300)

    C#面向对象设计模式纵横谈\9 结构型模式Composite组合模式.zip

    在这里与各位分享本人从网络上下载的C#面向对象设计模式纵横谈系列视频,共有25节,除了第一节需要各位贡献一点资源分以作为对本人上传资源的回馈,后面的其他资源均不需要... 这是第9节:结构型模式Composite组合模式

    设计模式:可复用面向对象软件的基础--详细书签版

    2.2.3 组合模式 27 2.3 格式化 27 2.3.1 封装格式化算法 27 2.3.2 compositor和composition 27 2.3.3 策略模式 29 2.4 修饰用户界面 29 2.4.1 透明围栏 29 2.4.2 monoglyph 30 2.4.3 decorator 模式 32 2.5...

Global site tag (gtag.js) - Google Analytics