设计模式之组合模式

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

优点:

1、高层模块调用简单。

2、节点自由添加。

缺点:

树叶和树枝使用是使用的实现类,违背了面向接口编程这一理念,与依赖倒置原则有冲突。

类图如下:


实现代码如下:

Component抽象构件角色:

package com.designpatterns.composite;
/**
 * @author WSYW126
 * @version 2016年5月6日下午6:48:31
 */
public abstract class Component {
	public abstract void doSomething();
}

Leaf叶子构件:

package com.designpatterns.composite;

/**
 * @author WSYW126
 * @version 2016年5月6日下午6:52:37
 */
public class Leaf extends Component {

	@Override
	public void doSomething() {
		System.out.println("I am leaf!");
	}

}

Composite树枝构件:

package com.designpatterns.composite;

import java.util.ArrayList;

/**
 * @author WSYW126
 * @version 2016年5月6日下午6:49:35
 */
public class Composite extends Component {
	private ArrayList<Component> list = new ArrayList<>();

	public void add(Component component) {
		list.add(component);
	}

	public void remove(Component component) {
		list.remove(component);
	}

	public ArrayList<Component> getChildren() {
		return this.list;
	}

	@Override
	public void doSomething() {
		System.out.println("I am branch!");
	}

}

测试类:

package com.designpatterns.composite;
/**
 * @author WSYW126
 * @version 2016年5月6日下午6:52:53
 */
public class Client {

	public static void main(String[] args) {
		Composite root = new Composite();
		root.doSomething();
		Composite branch = new Composite();
		Leaf leaf = new Leaf();
		root.add(branch);
		branch.add(leaf);
		display(root);
	}

	//递归遍历树
	private static void display(Composite root) {
		for (Component c : root.getChildren()) {
			if(c instanceof Leaf){
				c.doSomething();
			}else {
				display((Composite)c);
			}
		}
		
	}
}

这就是组合模式。


参考资料
设计模式之禅

备注
转载请注明出处
http://blog.csdn.net/wsyw126/article/details/51333823
by WSYW126

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值