1.开闭原则定义

开闭原则经典定义:软件实体应当对扩展开放,对修改关闭

软件实体包括以下几个部分:

  1. 项目中划分出的模块
  2. 类与接口
  3. 方法

开闭原则的含义是:当应用的需求改变时,在不修改软件实体的源代码或者二进制代码的前提下,可以扩展模块的功能,使其满足新的需求。


1.1 开闭原则的作用

1).对软件测试的影响

软件遵守开闭原则的话,软件测试时只需要对扩展的代码进行测试就可以了,因为原有的测试代码仍然能够正常运行。

2). 可以提高代码的可复用性

粒度越小,被复用的可能性就越大;在面向对象的程序设计中,根据原子和抽象编程可以提高代码的可复用性。

3). 可以提高软件的可维护性

遵守开闭原则的软件,其稳定性高和延续性强,从而易于扩展和维护。

1.2 开闭原则的实现方法

可以通过“抽象约束、封装变化”来实现开闭原则,即通过接口或者抽象类为软件实体定义一个相对稳定的抽象层,而将相同的可变因素封装在相同的具体实现类中。

因为抽象灵活性好,适应性广,只要抽象的合理,可以基本保持软件架构的稳定。而软件中易变的细节可以从抽象派生来的实现类来进行扩展,当软件需要发生变化时,只需要根据需求重新派生一个实现类来扩展就可以了。

1.3 使用开闭原则解决实际问题

下面我们以 编程语言的教程体系为例,来讲解如何使用开闭原则解决实际问题.

  • 首先创建一个教程接口 ICourse

    public interface ICourse {
    	Integer getId();
    	String getName();
    	Double getPrice();
    }
    
  • 教程有 C语言、C++、Java、Python等等,这里选择Java

    public class JavaCourse implements ICourse {
        private Integer id;
        private String name;
        private Double price;
    
        public JavaCourse(Integer id, String name, Double price) {
            this.id = id;
            this.name = name;
            this.price = price;
        }
    
        @Override
        public Integer getId() {
            return this.id;
        }
    
        @Override
        public String getName() {
            return this.name;
        }
    
        @Override
        public Double getPrice() {
            return this.price;
        }
    }
    
  • 现在要给 Java 教程做活动,问题来了如果修改 JavaCourse 类中的 getPrice() 方法,可能影响到其它地方的调用结果

    那么如何在不修改原有代码的前提下,实现价格优惠这个功能呢?

    我们可以添加一个处理优惠逻辑的类,即JavaDiscountCourse类

    public class JavaDiscountCourse extends JavaCourse {
       
        public JavaDiscountCourse(Integer id, String name, Double price) {
            super(id, name, price);
        }
    
        public Double getOriginPrice() {
            return super.getPrice();
        }
    
        public Double getPrice() {
            return super.getPrice() * 0.8;
        }
    }
    

从类图中可以看出 JavaDiscountCourse 中保留了覆盖 JavaCourse 的 getPrice() 方法,而不是直接修改 JavaCourse 类Course 中保留了覆盖 JavaCourse 的 getPrice() 方法,而不是直接修改 JavaCourse 类

在这里插入图片描述

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐