shared_ptr通过引用计数管理对象生命周期,避免内存泄漏;需包含头文件,推荐用make_shared创建,支持多指针共享同一对象,引用归零时自动释放资源;注意循环引用、裸指针混用等问题,适用共享所有权场景。

在C++中,shared_ptr 是现代内存管理的重要工具之一,属于智能指针的一种。它通过引用计数机制自动管理动态分配对象的生命周期,有效避免内存泄漏和重复释放问题。
shared_ptr 的基本用法
要使用 shared_ptr,需要包含头文件
创建 shared_ptr 的常用方式:
- 使用 make_shared:推荐方式,性能更好且异常安全。
- 直接构造:传入 new 返回的原始指针(不推荐裸 new,易出错)。
#include#include int main() { // 推荐:使用 make_shared auto ptr1 = std::make_shared (42); // 多个 shared_ptr 共享同一对象 auto ptr2 = ptr1; auto ptr3 = ptr1; std::cout << "Value: " << *ptr1 << "\n"; std::cout << "Reference count: " << ptr1.use_count() << "\n"; // 输出 3 ptr2.reset(); // ptr2 不再指向对象 std::cout << "After reset, count: " << ptr1.use_count() << "\n"; // 输出 2 return 0; }
shared_ptr 的原理剖析
shared_ptr 内部维护两个关键部分:
立即学习“C++免费学习笔记(深入)”;
- 指向实际对象的指针
- 控制块(control block):包含引用计数、弱引用计数和自定义删除器等信息
每次拷贝 shared_ptr,引用计数加1;每次析构或 reset,引用计数减1。归零时自动释放资源。
控制块通常与对象一起分配(如 make_shared 可优化),也可单独分配(如用裸指针构造时)。
常见陷阱与注意事项
虽然 shared_ptr 很强大,但使用不当仍可能引发问题:
- 循环引用:两个对象互相持有对方的 shared_ptr,导致引用计数永不归零。应使用 weak_ptr 打破循环。
- 不要混用裸指针和 shared_ptr:避免对 shared_ptr 管理的对象使用 delete 或多次构建 shared_ptr。
- 避免从 this 创建 shared_ptr:应在类内使用 enable_shared_from_this 来安全地生成 shared_ptr。
性能与适用场景
shared_ptr 带来便利的同时也有开销:
- 引用计数的原子操作在多线程下有性能成本
- 控制块额外内存占用
适用于需要共享所有权的场景,比如缓存、观察者模式、多线程间共享数据等。若仅单个所有者,优先考虑 unique_ptr。
基本上就这些。合理使用 shared_ptr 能大幅提升代码安全性和可维护性,理解其原理有助于写出更高效、更健壮的 C++ 程序。










