Java 设计模式 之 组合模式

http://www.verejava.com/?id=16999080076266

package com.composite.theory;

import java.util.List;

public class TestNode
{
	public static void main(String[] args)
	{
		Node root=new DefaultNode("世界");
		
		Node china=new DefaultNode("中国");
		Node america=new DefaultNode("美国");
		
		Node beijing=new DefaultNode("北京");
		Node shanghai=new DefaultNode("上海");
		china.add(beijing);
		china.add(shanghai);
		
		Node sanfancisco=new DefaultNode("三藩市");
		Node niuyue=new DefaultNode("纽约");
		america.add(sanfancisco);
		america.add(niuyue);
		
		root.add(china);
		root.add(america);
		
		System.out.println(root.getName());
		List<Node> childeNodes=root.getChildNodes();
		for(Node node :childeNodes)
		{
			System.out.println("----"+node.getName());
			List<Node> childNodes2=node.getChildNodes();
			for(Node node2 :childNodes2)
			{
				System.out.println("--------"+node2.getName());
			}
		}
	}
}





package com.composite.theory;

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

public abstract class Node
{
	protected String name;
	protected List<Node> childNodes;
	public Node(String name)
	{
		super();
		this.name = name;
		this.childNodes=new ArrayList<Node>();
	}
	
	public abstract void add(Node node);
	
	public abstract void remove(int index);
	
	public String getName()
	{
		return name;
	}
	public void setName(String name)
	{
		this.name = name;
	}
	public List<Node> getChildNodes()
	{
		return childNodes;
	}
	
	
	
}





package com.composite.theory;

public class DefaultNode extends Node
{

	public DefaultNode(String name)
	{
		super(name);
	}

	@Override
	public void add(Node node)
	{
		childNodes.add(node);
	}

	@Override
	public void remove(int index)
	{
		childNodes.remove(index);
	}

}

http://www.verejava.com/?id=16999080076266

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值