设计模式笔记:组合模式

组合模式

我的理解:
这个组合模式特别的容易理解, 就是树结构啊。^_^
  • 将树的节点(叶子和节点)抽象出来,并分别实现叶子和节点。
  • 节点中有保存节点的容器及对其的操作,还有对容器的递归方法的实现。
【类本身保存有自身接口的容器,以此递归】


2016年4月  

定义:
  • 组合模式又叫做部分-整体模式,它使我们树型结构的问题中,模糊了简单元素和复杂元素的概念,客户程序可以向处理简单元素一样来处理复杂元素,从而使得客户程序与复杂元素的内部结构解藕.
  • 组合模式可以优化处理递归或分级数据结构.有许多关于分级数据结构的例子,使得组合模式非常有用武之地.

类型:结构型模式

类图:


组成部分:

Component: 为参加组合的对象声明一个公共接口, 不管是组合还是叶结点.
Leaf: 在组合中表示叶子结点对象,叶子结点没有子结点.
Composite: 表示参加组合的有子对象的对象, 并给出树枝购件的行为.

使用场景:
1、用于对象的部分-整体层次结构,如树形菜单、文件夹菜单、部门组织架构图等;
2、对用户隐藏组合对象与单个对象的不同,使得用户统一地使用组合结构中的所有对象。

例子:

抽象节点接口:
    
    
public abstract class FolderComponent
{
private String name;
 
public String getName()
{
return name;
}
 
public void setName(final String name)
{
this.name = name;
}
 
public FolderComponent()
{
}
 
public FolderComponent(final String name)
{
this.name = name;
}
 
public abstract void add(FolderComponent component);
 
public abstract void remove(FolderComponent component);
 
public abstract void display();
}
叶子节点:
    
    
public class FileLeaf extends FolderComponent
{
public FileLeaf(final String name)
{
super(name);
}
 
@Override
public void add(final FolderComponent component)
{
//...
}
 
@Override
public void remove(final FolderComponent component)
{
//...
}
//递归的方法 Opetation()  
@Override
public void display()
{
System.out.println("FileLeaf:" + this.getName());
}
}
节点:
    
    
public class FolderComposite extends FolderComponent
{
private final List<FolderComponent> components;
 
public FolderComposite(final String name)
{
super(name);
this.components = new ArrayList<FolderComponent>();
}
 
public FolderComposite()
{
this.components = new ArrayList<FolderComponent>();
}
 
@Override
public void add(final FolderComponent component)
{
this.components.add(component);
}
 
@Override
public void remove(final FolderComponent component)
{
this.components.remove(component);
}
//递归的方法 Opetation()  
@Override
public void display()
{
System.out.println("FolderComposite---name:" + this.getName());
for (final FolderComponent component : components)
{
System.out.println("FolderComposite---component-name:" + component.getName());
}
}
}
调用:
    
    
public class Client
{
public static void main(final String[] args)
{
final FolderComponent leaf = new FileLeaf("runnable file");
leaf.display();
 
final FolderComponent folder = new FolderComposite("new folder");
folder.add(new FileLeaf("content1 in new folder"));
folder.add(new FileLeaf("content2 in new folder"));
folder.display();
}
}
 
结果:
FileLeaf:runnable file
FolderComposite---name:new folder
FolderComposite---component-name:content1 in new folder
FolderComposite---component-name:content2 in new folder




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小_杭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值