std::shared_ptr通过引用计数自动管理对象生命周期,推荐使用make_shared创建,多个指针可共享同一对象,引用计数为零时自动释放内存,支持自定义删除器并需避免循环引用和重复构造问题。

在C++中,std::shared_ptr 是一种智能指针,用于自动管理动态分配的对象生命周期。它通过引用计数机制实现多个 shared_ptr 共享同一个对象,当最后一个指向该对象的 shared_ptr 被销毁或重置时,对象会自动被删除,防止内存泄漏。
1. 基本用法:创建 shared_ptr
推荐使用 std::make_shared 来创建 shared_ptr,这是最安全且高效的方式。
- std::shared_ptr
ptr1 = std::make_shared (42); - std::shared_ptr<:string> ptr2 = std::make_shared<:string>("Hello");
你也可以用裸指针构造,但不推荐直接传 new 出来的指针,容易出错:
std::shared_ptr2. 多个 shared_ptr 共享同一对象
多个 shared_ptr 可以指向同一个对象,引用计数会自动增加。
立即学习“C++免费学习笔记(深入)”;
- auto p = std::make_shared
(100); - std::shared_ptr
q = p; // 引用计数变为 2 - std::shared_ptr
r; - r = p; // 引用计数变为 3
当 p、q、r 都离开作用域后,引用计数归零,内存自动释放。
3. 获取引用计数和检查有效性
可以使用 use_count() 查看当前引用数量,useful for debugging.
- auto a = std::make_shared
(5); - std::cout
- auto b = a;
- std::cout
用 if 判断指针是否为空:
if (a) { std::cout4. 自定义删除器(可选高级用法)
某些场景下需要自定义资源释放方式,比如关闭文件句柄或调用特定释放函数。
void close_file(FILE* fp) { if (fp) fclose(fp); }auto file_ptr = std::shared_ptr
即使提前 return 或异常发生,文件也能正确关闭。
5. 注意事项与常见陷阱
- 避免用同一个裸指针创建多个 shared_ptr,会导致重复释放: int* raw = new int(10);
- 不要把 this 指针交给 shared_ptr,除非继承 std::enable_shared_from_this
- 循环引用问题:两个对象互相持有对方的 shared_ptr,引用计数永不归零。此时应使用 std::weak_ptr 打破循环。
std::shared_ptr
std::shared_ptr
基本上就这些。合理使用 std::shared_ptr 能大幅提升代码安全性,减少内存管理错误。关键是优先用 make_shared,注意避免循环引用和重复构造问题。










