SOLID是面向对象设计的五大通用原则,适用于C++等所有支持OOP的语言,强调职责划分、依赖抽象与扩展性,需结合C++特性(虚函数、模板、组合等)灵活实践,而非机械套用其他语言模式。
SOLID 不是 C++ 专属的概念,而是面向对象设计的五大通用原则,由 Robert C. Martin 提出,适用于所有支持面向对象特性的语言(包括 C++)。它不依赖语法糖,而关注类与模块之间的职责划分、依赖关系和扩展方式。在 C++ 中践行 SOLID,关键在于合理使用类、虚函数、接口(抽象基类)、模板、组合等机制,而非强行套用 Java 或 C# 的写法。
一个类应该只有一个引起它变化的原因。C++ 中常见反例是把数据封装、序列化、网络发送、日志记录全塞进一个类里。
UserData 只管字段,UserSerializer 负责 JSON 序列化,UserRepository 处理存储逻辑#include 级联,加快编译对扩展开放,对修改关闭。C++ 实现时主要靠多态 + 抽象基类,或策略模式 + 模板参数。
class ILogger { public: virtual void log(const std::string&) = 0; };),具体实现(FileLogger、ConsoleLogger)可自由增删if (type == X) {...} else if (type == Y) {...} 这类分支逻辑子类型必须能替换其基类型,且不破坏程序正确性。C++ 中容易踩坑的地方集中在虚函数重写和 const 正确性上。
],子类缩窄成 [50,80] 就违反 LSP)const 和 noexcept 属性也应兼容(子类可比基类更严格,但不能更宽松)客户端不应依赖它不需要的接口。C++ 没有 interface 关键字,但可用轻量抽象基类模拟。
IEntity 同时含 render()、save()、updateAI()),按角色拆成 IRenderable、ISavable、IAIUpdatable
std::unique_ptr + std::unique_ptr)获得能力,而非从巨无霸基类继承#include "everything.h"
高层模块不应依赖低层模块,二者都应依赖抽象;抽象不应依赖细节,细节应依赖抽象。
OrderProcessor 依赖 IChargeService&,而不是 PayPalService 或 StripeService
基本上就这些。SOLID 在 C++ 中不是教条,而是帮助你识别僵化、脆弱、难以测试代码的“嗅探器”。用不用虚函数、要不要加一层抽象,得看变化点在哪、团队规模多大、性能是否敏感。过度设计比不设计更危险。