智能指针与继承结合需掌握多态赋值、安全转换和生命周期管理: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() { /*...*/ }
};
<p>struct Derived : Base {
void foo() override { /<em>...</em>/ }
void bar() { /<em> 特有方法 </em>/ }
};</p><p>std::shared_ptr<Derived> derived_ptr = std::make_shared<Derived>();
std::shared_ptr<Base> base_ptr = derived_ptr; // 合法:隐式向上转型
base_ptr->foo(); // 调用 Derived::foo()</p>这种转换是安全的,且引用计数正确共享。
std::unique_ptr
std::move
std::unique_ptr<Derived> derived_uptr = std::make_unique<Derived>(); std::unique_ptr<Base> base_uptr = std::move(derived_uptr); // 所有权转移
也可以使用
std::unique_ptr
std::unique_ptr<Base> base_uptr2 = std::make_unique<Derived>();
这种写法直接构造派生类对象并赋给基类指针,简洁高效。
当需要从基类智能指针获取派生类功能时,应使用
std::dynamic_pointer_cast
std::shared_ptr<Base> base_ptr = std::make_shared<Derived>();
<p>auto derived_ptr = std::dynamic_pointer_cast<Derived>(base_ptr);
if (derived_ptr) {
derived_ptr->bar(); // 安全调用派生类方法
}</p>对于
unique_ptr
dynamic_pointer_cast
shared_ptr
static_pointer_cast
在继承体系中,避免从智能指针获取裸指针长期保存。若必须向下转型,优先使用智能指针版本的转换函数。
使用
shared_ptr
std::weak_ptr
基本上就这些。掌握向上转型的自然赋值、向下转型的
dynamic_pointer_cast
unique_ptr
以上就是智能指针与继承如何结合 基类派生类转换技巧的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号