智能指针与继承结合需掌握多态赋值、安全转换和生命周期管理:std::shared_ptr支持隐式向上转型并共享引用计数,std::unique_ptr需通过std::move实现所有权转移或直接构造;向下转型应使用std::dynamic_pointer_cast确保安全;避免裸指针长期持有和shared_ptr循环引用,必要时用std::weak_ptr打破循环。

智能指针与继承结合使用时,核心在于正确管理对象生命周期,同时支持多态和类型转换。C++ 中的
std::shared_ptr和
std::unique_ptr都支持继承体系下的安全转换,但需掌握几个关键技巧。
智能指针支持多态赋值
当使用智能指针时,可以从派生类指针赋值给基类智能指针,这是多态的基础。
以
std::shared_ptr为例:
struct Base {
virtual ~Base() = default;
virtual void foo() { /*...*/ }
};
struct Derived : Base {
void foo() override { /.../ }
void bar() { / 特有方法 / }
};
std::shared_ptr derived_ptr = std::make_shared();
std::shared_ptr base_ptr = derived_ptr; // 合法:隐式向上转型
base_ptr->foo(); // 调用 Derived::foo()
这种转换是安全的,且引用计数正确共享。
unique_ptr 的继承转换需使用 move 或转换构造
std::unique_ptr不可复制,但支持通过
std::move实现所有权转移,也支持从派生类 unique_ptr 构造基类 unique_ptr。
std::unique_ptrderived_uptr = std::make_unique (); std::unique_ptr base_uptr = std::move(derived_uptr); // 所有权转移
也可以使用
std::unique_ptr的转换构造函数:
std::unique_ptrbase_uptr2 = std::make_unique ();
这种写法直接构造派生类对象并赋给基类指针,简洁高效。
向下转型:使用 dynamic_pointer_cast
当需要从基类智能指针获取派生类功能时,应使用
std::dynamic_pointer_cast进行安全的向下转型。
std::shared_ptrbase_ptr = std::make_shared (); auto derived_ptr = std::dynamic_pointer_cast
(base_ptr); if (derived_ptr) { derived_ptr->bar(); // 安全调用派生类方法 }
对于
unique_ptr,标准库未提供直接的
dynamic_pointer_cast,但可通过临时转为
shared_ptr再转回,或手动检查后
static_pointer_cast(需确保类型正确)。
避免裸指针传递与循环引用
在继承体系中,避免从智能指针获取裸指针长期保存。若必须向下转型,优先使用智能指针版本的转换函数。
使用
shared_ptr时注意父子对象可能造成循环引用,应使用
std::weak_ptr打破循环。
基本上就这些。掌握向上转型的自然赋值、向下转型的
dynamic_pointer_cast,以及
unique_ptr的 move 语义,就能安全高效地将智能指针与继承结合使用。










