软件架构设计原则之开闭原则

·  阅读 709

小知识,大挑战!本文正在参与「程序员必备小知识」创作活动

本文已参与「掘力星计划」,赢取创作大礼包,挑战创作激励金。

开闭原则(Open-Closed Principle,OCP)是指一个软件实体(如类、模块和函数)应该对扩展开放,对修改关闭。所谓的开闭,也正是对扩展和修改两个行为的一个原则。它强调的是用抽象构建框架,用实现扩展细节,可以提高软件系统的可复用性及可维护性。开闭原则是面向对象设计中最基础的设计原则,它指导我们如何建立稳定、灵活的系统。例如版本更新,我们尽可能不修改源代码,但是可以增加新功能。 在现实生活中开闭原则也有体现。比如,很多互联网公司都实行弹性作息时间,只规定每天工作8小时。意思就是说,对于每天工作8小时这个规定是关闭的,但是你什么时候来、什么时候走是开放的。早来早走,晚来晚走。 开闭原则的核心思想就是面向抽象编程,接下来我们来看一段代码。 以咕泡学院的课程体系为例,首先创建一个课程接口ICourse:

public interface ICourse {
    Integer getId();
    String getName();
    Double getPrice();
}
复制代码

整个课程生态有Java架构、大数据、人工智能、前端、软件测试等,我们来创建一个Java架构课程的类JavaCourse:

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;
    }
    public Integer getId() {
        return this.Id;
    }
    public String getName() {
        return this.name;
    }
    public Double getPrice() {
        return this.price;
    }
}
复制代码

现在我们要给Java架构课程做活动,价格优惠。如果修改JavaCourse中的getPrice()方法,则存在一定的风险,可能影响其他地方的调用结果。我们如何在不修改原有代码的前提前下,实现价格优惠这个功能呢?现在,我们再写一个处理优惠逻辑的类JavaDiscountCourse(思考一下为什么要叫JavaDiscountCourse,而不叫DiscountCourse):


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.61;
    }
}
复制代码

回顾一下,简单看一下类结构图,如下图所示。

file

本文为“Tom弹架构”原创,转载请注明出处。技术在于分享,我分享我快乐!如果本文对您有帮助,欢迎关注和点赞;如果您有任何建议也可留言评论或私信,您的支持是我坚持创作的动力。关注“Tom弹架构”可获取更多技术干货!

【推荐】收藏本文,相当于收藏一本“设计模式”的书

其他设计原则

依赖倒置原则(Dependence Inversion Principle,DIP)

单一职责(Simple Responsibility Pinciple,SRP)

接口隔离原则(Interface Segregation Principle, ISP)

迪米特原则(Law of Demeter LoD)

里氏替换原则(Liskov Substitution Principle,LSP)

合成复用原则(Composite/Aggregate Reuse Principle,CARP)

「欢迎在评论区讨论,掘金官方将在掘力星计划活动结束后,在评论区抽送100份掘金周边,抽奖详情见活动文章」

分类:
后端
标签:
收藏成功!
已添加到「」, 点击更改