首页 > 其他分享 >面向对象的7种设计原则(4)-合成聚合复用原则

面向对象的7种设计原则(4)-合成聚合复用原则

时间:2022-09-20 16:03:20浏览次数:65  
标签:聚合 原则 对象 合成 复用 面向对象 超类 继承

合成复用原则

在一个新的对象里面使用一些已有的对象,使之成为新对象的一部分;新的对象通过向这些对象的委派达到复用这些对象的目的。

如果两个类是“Has-a”关系应使用合成、聚合,如果是“Is-a”关系可使用继承。"Is-A"是严格的分类学意义上定义,意思是一个类是另一个类的"一种"。而"Has-A"则不同,它表示某一个角色具有某一项责任。

什么是合成?什么是聚合?

合成(Composition)和聚合(Aggregation)都是关联(Association)的特殊种类。

聚合

聚合用来表示“拥有”关系或者整体与部分的关系。代表部分的对象有可能会被多个代表整体的对象所共享,而且不一定会随着某个代表整体的对象被销毁或破坏而被销毁或破坏,部分的生命周期可以超越整体。例如,班级和学生,当班级删除后,学生还能存在,学生可以被培训机构引用。在设计中, 聚合不应该频繁出现,这样会增大设计的耦合度。

聚合关系UML类图

class Student {
 
}
 
class Classes{
 
         private Student student;
 
         publicClasses(Student student){
 
                   this.student=student;
        }
 
}

合成

合成用来表示一种强得多的“拥有”关系。在一个合成关系里,部分和整体的生命周期是一样的。一个合成的新对象完全拥有对其组成部分的支配权,包括它们的创建和湮灭等。使用程序语言的术语来说,合成而成的新对象对组成部分的内存分配、内存释放有绝对的责任。一个合成关系的成分对象是不能与另一个合成关系共享的。

合成关系UML类图

class Room{
 
         public Room createRoom(){
                   System.out.println(“创建房间”);
                   returnnew Room();
          } 
 }
 
class House{
 
         private Room room;
 
         public House(){ 
               room=new Room();
          }
 
         public void createHouse(){
                room.createRoom();
         } 
  }

换句话说,合成是值的聚合(Aggregation by Value),而一般说的聚合是引用的聚合(Aggregation by Reference)。

为什么使用合成/聚合复用,而不使用继承复用?

在面向对象的设计里,有两种基本的方法可以在不同的环境中复用已有的设计和实现,即通过合成/聚合复用和通过继承复用。两者的特点和区别,优点和缺点如下。

合成/聚合复用

由于合成或聚合可以将已有对象纳入到新对象中,使之成为新对象的一部分,因此新对象可以调用已有对象的功能。这样做的好处有

  • 新对象存取成分对象的唯一方法是通过成分对象的接口。

  • 这种复用是黑箱复用,因为成分对象的内部细节是新对象看不见的。

  • 这种复用支持包装。

  • 这种复用所需的依赖较少。

  • 每一个新的类可以将焦点集中到一个任务上。

  • 这种复用可以再运行时间内动态进行,新对象可以动态地引用与成分对象类型相同的对象。

一般而言,如果一个角色得到了更多的责任,那么可以使用合成/聚合关系将新的责任委派到合适的对象。当然,这种复用也有缺点。最主要的缺点就是通过这种复用建造的系统会有较多的对象需要管理。

继承复用

继承复用通过扩展一个已有对象的实现来得到新的功能,基类明显的捕获共同的属性和方法,而子类通过增加新的属性和方法来扩展超类的实现。继承是类型的复用。

继承复用的优点

  • 新的实现较为容易,因为超类的大部分功能可以通过继承关系自动进入子类。

  • 修改或扩展继承而来的实现较为容易。

继承复用的缺点

  • 继承复用破坏包装,因为继承将超类的实现细节暴露给了子类。因为超类的内部细节常常对子类是透明的,因此这种复用是透明的复用,又叫“白箱”复用。

  • 如果超类的实现改变了,那么子类的实现也不得不发生改变。因此,当一个基类发生了改变时,这种改变会传导到一级又一级的子类,使得设计师不得不相应的改变这些子类,以适应超类的变化。

  • 从超类继承而来的实现是静态的,不可能在运行时间内发生变化,因此没有足够的灵活性。

由于继承复用有以上的缺点,所有尽量使用合成/聚合而不是继承来达到对实现的复用,是非常重要的设计原则。

标签:聚合,原则,对象,合成,复用,面向对象,超类,继承
From: https://www.cnblogs.com/leepandar/p/16711328.html

相关文章

  • 面向对象的7种设计原则(3)-依赖倒置原则
    依赖倒置原则Highlevelmodulesshouldnotdependuponlowlevelmodules.Bothshoulddependuponabstractions.高层模块不应该依赖低层模块,两者都应该依赖其抽象(......
  • 面向对象的7种设计原则(1)-单一职责原则
    永远不要让一个类存在多个改变的理由。单一原则表明,如果你有多个原因去改变一个类,那么应该把这些引起变化的原因分离开,把这个类分成多个类,每个类只负责处理一种改变。当......
  • 面向对象的7种设计原则(2)-接口隔离原则
    定义InterfaceSegregationPrinciple客户端不应依赖它不需要的接口类间的依赖关系应该建立在最小的接口上其实通俗来理解就是,不要在一个接口里面放很多的方法,这......
  • 面向对象的7种设计原则(7)-开闭原则
    开闭原则开闭原则是面向对象世界里最基础的设计原则,它指导我们如何建立一个稳定,灵活,可扩展的系统。开闭原则定义如下:Softwareentitieslikeclasses,modulesandfunct......
  • 面向对象的7种设计原则(6)-迪米特原则
    迪米特原则迪米特原则(LawofDemeter)又叫最少知道原则(LeastKnowledgePrinciple),可以简单说成:talkonlytoyourimmediatefriends,只与你直接的朋友们通信,不要跟“陌生......
  • 面向对象的7种设计原则(5)-里氏代换原则
    定义里氏代换原则(LiskovSubstitutionPrincipleLSP)面向对象设计的基本原则之一。里氏代换原则中说,任何基类可以出现的地方,子类一定可以出现。LSP是继承复用的基石,只......
  • 面向对象---多态的基础语法
    多态的基础语法Q:什么是多态?A:多种形态,多种状态。学习多态基础语法之前,我们需要普及两个概念。注意---java中允许向上转型,也允许向下转型无论是向上转型,还是向下转型,两......
  • 面向对象
    面向对象目录面向对象面向过程&面向对象的关联面向对象本质特点三大特性面向过程&面向对象的关联​在我们真正接触面向对象之前,我们要先回顾一下什么是面向过程。面向......
  • Java面向对象数据结构完全学习教程 pdf
    高清扫描版下载链接:https://pan.baidu.com/s/1m6FOQFqsjqYSbKXKs8zHjQ点击这里获取提取码 ......
  • 设计模式---六大设计原则
    六大设计原则单一职责原则接口隔离原则开闭原则依赖倒置原则里氏代换原则迪米特法则单一职责原则我们分别看两个案例,一个是遵守单一职责原则,另一个是违背。违背......