设计模式-组合模式

UML类图

在这里插入图片描述

使用场景

多叉树的实现,如文件夹-文件,公司组织架构等。
需要对结点有较高的抽象性能,如果结点之间属性有较多不同,则难以实现组合模式。
在这里插入图片描述

代码实现

public abstract class Component {
	protected String name;
	public Component(String name){
		this.name = name;
	}
	public abstract void add(Component c);
	public abstract void remove(Component c);
	public abstract void display(int depth);
}
import java.util.ArrayList;
import java.util.List;

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

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

	@Override
	public void remove(Component c) {
		children.remove(c);
	}
	
	@Override
	public void display(int depth) {
		String temp = "";
		for (int i = 0; i < depth; i++) {
			temp+= "-";
		}
		System.out.println(temp + this.name);		
		for (Component component : children) {
			component.display(depth + 1);
		}
	}
}
public class Leaf extends Component {
	public Leaf(String name) {
		super(name);
	}
	@Override
	public void add(Component c) {}

	@Override
	public void remove(Component c) {}

	@Override
	public void display(int depth) {
		String temp = "";
		for (int i = 0; i < depth; i++) {
			temp+= "-";
		}
		System.out.println(temp + this.name);
	}
}
public class Client {
	public static void main(String[] args) {
		Component root = new Composite("a");
		Component b = new Composite("b");
		Component c = new Composite("c");
		
		Component d = new Leaf("d");
		Component e = new Leaf("e");
		b.add(d);
		b.add(e);
		
		root.add(b);
		root.add(c);
		
		root.display(1);
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值