期权软件开发复用原则

作者:adminy 发布时间:2019-12-26 浏览量:

  一、定义


  期权软件开发复用原则经常又叫做合成复用原则,尽量使用对象组合,而不是继承来达到复用的目的。在一个新的对象里面使用一些已有的对象,使之成为新对象的一部分;新对象通过向这些对象的委派达到复用已有功能的目的。简而言之,要尽量使用合成/聚合,尽量不要使用继承。


  二、原则分析


  1、在面向对象设计中,可以通过两种基本方法在不同的环境中复用已有的设计和实现,即通过组合/聚合关系或通过继承。


  (1)继承复用:实现简单,易于扩展。破坏系统的封装性;从基类继承而来的实现是静态的,不可能在运行时发生改变,没有足够的灵活性;只能在有限的环境中使用。


  (2)组合/聚合复用:耦合度相对较低,选择性地调用成员对象的操作;可以在运行时动态进行。


  2、组合/聚合可以使系统更加灵活,类与类之间的耦合度降低,一个类的变化对其他类造成的影响相对较少,因此一般首选使用组合/聚合来实现复用;其次才考虑继承,在使用继承时,需要严格遵循里氏代换原则,有效使用继承会有助于对问题的理解,降低复杂度,而滥用继承反而会增加系统构建和维护的难度以及系统的复杂度,因此需要慎重使用继承复用。


  3、此原则和里氏代换原则氏相辅相成的,两者都是具体实现"开-闭"原则的规范。违反这一原则,就无法实现“开-闭”原则,首先我们要明白合成和聚合的概念:


  (1)合成:表示一个整体与部分的关系,指一个依托整体而存在的关系。在UML中,组合关系用带实心菱形的直线表示。


  (2)聚合:聚合是比合成关系的一种更强的依赖关系,也表示整体与部分的关系。在UML中,聚合关系用带空心菱形的直线表示。