组合模式的安全模式与透明模式

3人阅读 评论(0) 收藏 举报
分类:

转载自 树形结构的处理——组合模式(四)

1 透明组合模式与安全组合模式

      通过引入组合模式,Sunny公司设计的杀毒软件具有良好的可扩展性,在增加新的文件类型时,无须修改现有类库代码,只需增加一个新的文件类作为AbstractFile类的子类即可,但是由于在AbstractFile中声明了大量用于管理和访问成员构件的方法,例如add()remove()等方法,我们不得不在新增的文件类中实现这些方法,提供对应的错误提示和异常处理。为了简化代码,我们有以下两个解决方案:

      解决方案一:将叶子构件的add()remove()等方法的实现代码移至AbstractFile类中,由AbstractFile提供统一的默认实现,代码如下所示:

[java] view plain copy
  1. //提供默认实现的抽象构件类  
  2. abstract class AbstractFile {  
  3.     public void add(AbstractFile file) {  
  4.         System.out.println("对不起,不支持该方法!");  
  5.     }  
  6.       
  7.     public void remove(AbstractFile file) {  
  8.         System.out.println("对不起,不支持该方法!");  
  9.     }  
  10.       
  11.     public AbstractFile getChild(int i) {  
  12.         System.out.println("对不起,不支持该方法!");  
  13.         return null;  
  14.     }  
  15.       
  16.     public abstract void killVirus();  
  17. }  

      如果客户端代码针对抽象类AbstractFile编程,在调用文件对象的这些方法时将出现错误提示。如果不希望出现任何错误提示,我们可以在客户端定义文件对象时不使用抽象层,而直接使用具体叶子构件本身,客户端代码片段如下所示:

[java] view plain copy
  1. class Client {  
  2.     public static void main(String args[]) {  
  3.         //不能透明处理叶子构件  
  4.         ImageFile file1,file2;  
  5.         TextFile file3,file4;  
  6.         VideoFile file5;  
  7.         AbstractFile folder1,folder2,folder3,folder4;  
  8.         //其他代码省略  
  9.       }  
  10. }  

      这样就产生了一种不透明的使用方式,即在客户端不能全部针对抽象构件类编程,需要使用具体叶子构件类型来定义叶子对象。

      解决方案二:除此之外,还有一种解决方法是在抽象构件AbstractFile中不声明任何用于访问和管理成员构件的方法,代码如下所示:

[java] view plain copy
  1. abstract class AbstractFile {  
  2.     public abstract void killVirus();  
  3. }  

      此时,由于在AbstractFile中没有声明add()、remove()等访问和管理成员的方法,其叶子构件子类无须提供实现;而且无论客户端如何定义叶子构件对象都无法调用到这些方法,不需要做任何错误和异常处理,容器构件再根据需要增加访问和管理成员的方法,但这时候也存在一个问题:客户端不得不使用容器类本身来声明容器构件对象,否则无法访问其中新增的add()、remove()等方法,如果客户端一致性地对待叶子和容器,将会导致容器构件的新增对客户端不可见,客户端代码对于容器构件无法再使用抽象构件来定义,客户端代码片段如下所示:

[java] view plain copy
  1. class Client {  
  2.     public static void main(String args[]) {  
  3.           
  4.         AbstractFile file1,file2,file3,file4,file5;  
  5.         Folder folder1,folder2,folder3,folder4; //不能透明处理容器构件  
  6.         //其他代码省略  
  7.     }  
  8. }  

      在使用组合模式时,根据抽象构件类的定义形式,我们可将组合模式分为透明组合模式和安全组合模式两种形式:

      (1) 透明组合模式

      透明组合模式中,抽象构件Component中声明了所有用于管理成员对象的方法,包括add()remove()以及getChild()等方法,这样做的好处是确保所有的构件类都有相同的接口。在客户端看来,叶子对象与容器对象所提供的方法是一致的,客户端可以相同地对待所有的对象。透明组合模式也是组合模式的标准形式,虽然上面的解决方案一在客户端可以有不透明的实现方法,但是由于在抽象构件中包含add()remove()等方法,因此它还是透明组合模式,透明组合模式的完整结构如图11-6所示:

11-6  透明组合模式结构图

      透明组合模式的缺点是不够安全,因为叶子对象和容器对象在本质上是有区别的。叶子对象不可能有下一个层次的对象,即不可能包含成员对象,因此为其提供add()remove()以及getChild()等方法是没有意义的,这在编译阶段不会出错,但在运行阶段如果调用这些方法可能会出错(如果没有提供相应的错误处理代码)。

      (2) 安全组合模式

      安全组合模式中,在抽象构件Component中没有声明任何用于管理成员对象的方法,而是在Composite类中声明并实现这些方法。这种做法是安全的,因为根本不向叶子对象提供这些管理成员对象的方法,对于叶子对象,客户端不可能调用到这些方法,这就是解决方案二所采用的实现方式。安全组合模式的结构如图11-7所示:

11-7  安全组合模式结构图

       安全组合模式的缺点是不够透明,因为叶子构件和容器构件具有不同的方法,且容器构件中那些用于管理成员对象的方法没有在抽象构件类中定义,因此客户端不能完全针对抽象编程,必须有区别地对待叶子构件和容器构件。在实际应用中,安全组合模式的使用频率也非常高,在Java AWT中使用的组合模式就是安全组合模式。


查看评论

* 24种设计模式——组合模式

将对象组合成树形结构,以表示“部分-整体”的层次结构,使得用户对单个对象和组合对象的使用具有一致性。 一、公司组织架构1(接口篇) 1. 公司人员接口 public interface ICorp...
  • yifanSJ
  • yifanSJ
  • 2017-07-28 18:34:02
  • 255

树形结构的处理——组合模式(四):透明组合模式与安全组合模式

11.4 透明组合模式与安全组合模式通过引入组合模式,Sunny公司设计的杀毒软件具有良好的可扩展性,在增加新的文件类型时,无须修改现有类库代码,只需增加一个新的文件类作为AbstractFile类的...
  • will130
  • will130
  • 2016-01-19 11:06:52
  • 681

组合模式——Composition

1、 组合模式 将对象组合成树形结构以表示“部分-整体”的层次结构。组合模式使得用户对单个对象 和组合对象的使用具有一致性。 组合模式的结构图如下: Component为组合中的对象声明接...
  • Nancy_m
  • Nancy_m
  • 2012-11-24 22:45:18
  • 1134

Java设计模式——组合模式(Composite Pattern)

场景一 描述:大家在上学的时候应该都学过“数据结构”这门课程吧,还记得其中有一节叫“二叉树”吧,我们上学那会儿这一章节是必考内容,左子树,右子树,什么先序遍历后序遍历什么,重点就是二叉树的的遍历,我...
  • u012401711
  • u012401711
  • 2016-09-26 23:42:10
  • 1154

组合模式(Composite Pattern)(一):组合模式介绍

一、意图 将对象组合成树形结构以表示“部分-整体”的层次结构。Composite模式使得用户对单个对象和组合对象的使用具有一致性。 二、适用性 • 你想表示对象的...
  • jialinqiang
  • jialinqiang
  • 2013-05-20 22:30:49
  • 3781

结构型设计模式(一)(适配器模式,桥接模式,组合模式,装饰模式)

结构模式用来描述的是如何组合类 的对象一获得更大的结构,分为类描述和对象描述。类描述的是如何通过继承提供更有用的接口而对象接口描述的是通过使用对象的组合或将对象含在其他对象里面一伙的更有用的结构》 ...
  • l_z_w99
  • l_z_w99
  • 2016-12-30 18:37:54
  • 850

Android设计模式(十八)-组合模式

组合模式,也称作部分整体模式。是结构型设计模式之一。组合模式画成图就是数据结构中的树结构,有一个根节点,然后有很多分支。将最顶部的根节点叫做根结构件,将有分支的节点叫做枝干构件,将没有分支的末端节点叫...
  • qq_25806863
  • qq_25806863
  • 2017-04-07 16:02:34
  • 1088

组合模式(Composite Pattern )

当我想去了解组合模式的时候,网上搜一下,有很多优秀的文章,但很多人都在直接给出了组合模式的UML图,然后就去讲解什么是组合,组合有什么优缺点。 我承认他们也许讲的很好,但我并没有一下子就能理解了组合...
  • caiwenfeng_for_23
  • caiwenfeng_for_23
  • 2012-12-31 15:08:56
  • 8344

设计模式:组合模式(COMPOSITE)|菜鸟教程

定义组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,用来表示部分以及整体层次。这种类型的设计模式属于结构型模...
  • lory17
  • lory17
  • 2017-03-17 22:41:33
  • 490

设计模式之组合模式-树形结构的处理

一、描述:      对于树形结构,当容器对象(如文件夹)的某一个方法被调用时,将遍历整个树形结构,寻找也包含这个方法的成员对象(可以是容器对象,也可以是叶子对象)并调用执行,牵一而动百,其中使用了...
  • zhulongxi
  • zhulongxi
  • 2016-09-25 12:01:07
  • 1874
    个人资料
    持之以恒
    等级:
    访问量: 1万+
    积分: 497
    排名: 10万+
    文章存档