boxmoe_header_banner_img

Hello! 欢迎来到悠悠畅享网!

文章导读

C++设计原则SOLID 面向对象设计规范


avatar
作者 2025年8月28日 17

SOLID原则在C++中通过单一职责、开闭原则、里氏替换、接口隔离和依赖倒置提升代码质量,具体表现为:类职责单一,扩展通过继承抽象基类实现,子类不破坏父类行为,接口按需拆分,高层模块依赖抽象而非具体实现,从而增强可维护性与可扩展性。

C++设计原则SOLID 面向对象设计规范

SOLID 是面向对象设计中的五个核心原则,旨在提升代码的可维护性、可扩展性和可重用性。尽管这些原则最初不局限于 C++,但在 C++ 开发中尤其重要,因为 C++ 支持多态、继承和抽象等特性,容易因设计不当导致代码耦合严重、难以测试和维护。以下是 SOLID 原则在 C++ 中的具体体现和应用方式。

单一职责原则(Single Responsibility Principle, SRP)

一个类应该只有一个引起它变化的原因。换句话说,一个类只负责一项职责。

在 C++ 中,如果一个类既负责数据解析,又负责文件读写,还负责日志记录,那么它就违背了 SRP。应当将这些职责拆分到不同的类中。

例如:

  • 定义一个
    FileReader

    类专门处理文件读取

  • 定义一个
    DataParser

    类处理数据解析

  • 定义一个
    Logger

    类处理日志输出

这样每个类只关注自己的任务,修改日志格式不会影响文件读取逻辑。

立即学习C++免费学习笔记(深入)”;

开闭原则(Open/Closed Principle, OCP)

软件实体(类、模块、函数等)应该对扩展开放,对修改关闭。

在 C++ 中,可以通过抽象基类和多态实现这一原则。当需要新增功能时,不修改已有代码,而是通过继承和重写来扩展行为。

例如:

  • 定义一个抽象类
    Shape

    ,包含虚函数

    area()
  • 派生类
    Circle

    Rectangle

    实现各自的面积计算

  • 后续添加
    Triangle

    时,无需修改使用

    Shape

    的代码

这样客户端代码依赖于抽象,而不是具体实现,易于扩展。

里氏替换原则(Liskov Substitution Principle, lsp

子类对象应该能够替换其父类对象,而不会破坏程序的正确性。

在 C++ 中,如果派生类重写了基类方法,但改变了其行为契约(如前置条件更严格或后置条件更弱),就可能违反 LSP。

常见违反示例:

  • Square

    继承自

    Rectangle

    ,但设置宽高时互相影响

  • 重写虚函数时抛出额外异常或改变返回逻辑

应确保子类行为与父类语义一致,必要时使用组合替代继承。

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

客户端不应依赖于它们不需要的接口。应将大接口拆分为更小、更具体的接口。

C++ 中没有原生的“接口”关键字,但可通过纯虚类模拟接口。避免让一个类实现大量无关的纯虚函数

例如:

  • 不要定义一个包含
    print()

    scan()

    fax()

    的大接口

  • 应拆分为
    Printer

    Scanner

    Faxmachine

    三个独立接口

  • 多功能设备类可同时继承多个接口,而简单打印机只需实现
    Printer

这样避免了“胖接口”带来的冗余实现。

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

高层模块不应依赖低层模块,二者都应依赖抽象。抽象不应依赖细节,细节应依赖抽象。

在 C++ 中,这意味着避免在高层类中直接实例化低层类。应通过接口或抽象类进行依赖注入。

例如:

  • 一个
    ReportGenerator

    类不应直接使用

    FileLogger
  • 应依赖一个
    Logger

    抽象接口,运行时传入具体实现

  • 可通过构造函数或函数参数传入依赖(依赖注入)

这样便于替换实现(如换成

ConsoleLogger

NetworkLogger

),也利于单元测试。

基本上就这些。在 C++ 项目中合理应用 SOLID 原则,能显著提升代码质量,尤其是在大型系统或长期维护项目中。虽然过度设计需避免,但基本的抽象和解耦是稳健架构的基础。



评论(已关闭)

评论已关闭