私有继承用于实现复用而非“is-a”关系,将基类成员变为派生类私有,禁止外部访问与向上转型。1. 基类成员在派生类中全为private;2. 不支持类型转换和多态;3. 适用于需访问protected成员或重写虚函数但不暴露接口的场景;4. 相比组合,私有继承更便于复用内部逻辑,如Timer示例中复用start()并重写onTick();5. 常用于实现辅助功能、限制接口暴露或隔离实现细节;6. 应避免滥用,优先考虑组合或工具类。关键是区分“拥有功能”用组合,“实现行为”且涉protected/虚函数时选私有继承。

私有继承在C++中是一个相对少见但有特定用途的机制。它与公有继承和保护继承不同,主要体现在继承权限和设计意图上。理解私有继承的关键在于:它不是为了“is-a”关系,而是为了“实现复用”或“受限组合”。
私有继承的基本特性
当一个类以私有方式继承另一个类时:
- 基类的所有成员(包括public和protected)在派生类中都变为private成员。
 - 派生类对象无法被当作基类类型使用,即没有类型公开转换关系。
 - 基类的public成员只能在派生类内部访问,外部代码无法通过派生类调用它们。
 - 私有继承关系不会出现在接口层面,对用户透明。
 
简单来说,私有继承切断了“向上转型”的能力,打破了面向对象中的多态支持,因此不适合用于多态设计。
私有继承 vs 成员组合:何时选择前者?
通常我们推荐“优先使用组合而非继承”,但在某些情况下,私有继承比组合更合适:
- 需要访问基类的protected成员:如果基类有一些protected成员函数或变量,而你希望在派生类中使用它们,但又不希望暴露接口,这时私有继承是唯一选择。
 - 需要重写基类的虚函数:如果基类定义了虚函数,你想在派生类中重写它,但又不希望外部通过基类指针调用你的类(即不需要多态对外暴露),私有继承可以实现这一点。
 - 节省代码冗余:当你想复用一个类的大量实现逻辑,但不想改变其接口可见性,私有继承可避免手动转发大量函数。
 
举个例子:
立即学习“C++免费学习笔记(深入)”;
 class Timer { protected:     virtual void onTick() { }  public:     void start() {         // 模拟定时器触发         onTick();     } };  class RealTimeChecker : private Timer { protected:     void onTick() override {         // 检查实时性逻辑     }  public:     void enableCheck() {         start(); // 复用Timer的启动逻辑     } }; 
这里RealTimeChecker不需要外界把它当成Timer,但需要重写onTick并复用start()逻辑。使用私有继承比把Timer作为成员更直接。
典型使用场景
- 实现辅助功能类:比如一个类需要定时行为、日志记录、状态机等基础设施,但不想暴露这些机制的接口。
 - 限制接口暴露:防止用户误用基类接口。例如,你继承一个容器类但只提供部分操作,避免用户调用不必要的方法。
 - 替代多重继承中的接口隔离:结合公有继承接口和私有继承实现,实现类似Java中“实现接口+私有继承工具类”的效果。
 
注意事项与建议
- 私有继承会使类之间的耦合更强,应谨慎使用。
 - 多数情况下,使用组合+委托更清晰、更灵活。
 - 若只是为了复用非虚函数,考虑将功能提取为独立的工具类或命名空间函数。
 - 不要为了“偷懒不写成员变量”而滥用私有继承。
 
基本上就这些。私有继承不是主流手段,但它在特定场合下能提供简洁且有效的实现方式。关键是明确目的:你是想“拥有一个功能”,还是“实现一种行为”。如果是前者,用组合;如果是后者且涉及protected/虚函数,私有继承值得考虑。


