组合模式(Composite)

定义

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


解决的问题

让客户端不再区分操作的是组合对象还是叶子对象,而是以一个统一的方式来操作。

实现这个目标的关键就是设计一个抽象的组件类,让它可以代表组合对象和叶子对象。


模式结构



Component:组合中的对象声明接口,在适当情况下,实现所有类共有接口的行为。声明一个接口用于访问和管理Component的子部件
Leaf:叶节点对象,叶节点没有子节点。由于叶节点不能增加分支和树叶,所以叶节点的Add和Remove没有实际意义。
Composite:实现Componet的相关操作,比如Add和Remove操作。有叶节点行为,用来存储叶节点集合
children:用来存储叶节点集合


源代码


public abstract class Component {
	protected String name;
	
	public abstract void add(Component component);
	
	public abstract void remove(Component component);
	
	public abstract void dispaly(int depth);

}

public class Leaf extends Component {
	
	public Leaf(String name){
		this.name=name;
	}

	@Override
	public void add(Component component) {
		System.out.println("不能向叶子节点添加子节点");
	}

	@Override
	public void remove(Component component) {
		System.out.println("叶子节点没有子节点");
	}

	@Override
	public void dispaly(int depth) {
		StringBuilder builder=new StringBuilder("");
		for(int i=0;i<depth;i++){
			builder.append("-");
		}
		System.out.println(builder.toString()+name);
	}

}


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

public class Composite extends Component {
	
	private List<Component> children;
	
	public Composite(String name){
		this.name=name;
		if(children==null){
			children=new ArrayList<Component>();
		}
	}

	@Override
	public void add(Component component) {
		children.add(component);
	}

	@Override
	public void remove(Component component) {
		children.remove(component);
	}

	@Override
	public void dispaly(int depth) {
		StringBuilder builder=new StringBuilder("");
		for(int i=0;i<depth;i++){
			builder.append("-");
		}
		System.out.println(builder.toString()+name);
		for(Component component:children){
			component.dispaly(depth+2);
		}
		
	}

}

public class Client {
	
	public static void main(String[] args) {
		Component root=new Composite("计算机技术");
		Component c1=new Composite("编程技术");
		Component c2=new Composite("数据库技术");
		Component c1_1=new Leaf("Java");
		Component c1_2=new Leaf("C#");
		c1.add(c1_1);
		c1.add(c1_2);
		Component c2_1=new Leaf("MySQL");
		Component c2_2=new Leaf("Oracle");
		c2.add(c2_1);
		c2.add(c2_2);
		root.add(c1);
		root.add(c2);
		root.dispaly(1);
	}

}

输出结果

-计算机技术
---编程技术
-----Java
-----C#
---数据库技术
-----MySQL
-----Oracle



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值