答案是std::shared_ptr通过引用计数实现共享所有权,推荐使用std::make_shared创建,赋值时引用计数递增,支持自定义删除器处理特殊资源,引用计数操作线程安全但对象访问需额外同步,合理使用可有效避免内存泄漏。

在C++11中,std::shared_ptr 是一种智能指针,用于实现多个指针共享同一个对象的所有权。它通过引用计数机制自动管理资源的生命周期,当最后一个 shared_ptr 被销毁或重置时,所管理的对象会自动被删除,避免内存泄漏。
基本用法:创建 shared_ptr
使用 std::make_shared 是创建 shared_ptr 的推荐方式,它更高效且异常安全。
- std::shared_ptr
ptr1 = std::make_shared (42); - std::shared_ptr<:string> strPtr = std::make_shared<:string>("Hello");
此时,ptr1 拥有一个 int 对象,引用计数为 1。
共享资源:多个 shared_ptr 指向同一对象
当把一个 shared_ptr 赋值给另一个时,引用计数自动递增。
立即学习“C++免费学习笔记(深入)”;
- auto ptr2 = ptr1; // 引用计数变为 2
- std::shared_ptr
ptr3 = ptr1; // 计数变为 3
ptr1、ptr2、ptr3 共享同一块内存。只要至少有一个 shared_ptr 存在,对象就不会被释放。
自定义删除器:处理特殊资源
如果需要管理非 new 分配的资源(如文件句柄、C 风格数组),可以指定删除器。
- auto deleter = [](int* p) { delete[] p; };
- std::shared_ptr
array(new int[10], deleter);
这样在 shared_ptr 析构时会调用 delete[] 而不是 delete,避免内存错误。
线程安全与性能注意点
shared_ptr 的引用计数操作是线程安全的,但指向的对象本身不保证线程安全。多个线程同时修改共享对象仍需加锁。频繁拷贝 shared_ptr 会有原子操作开销,应避免不必要的复制。
基本上就这些。合理使用 shared_ptr 可以大幅减少手动内存管理带来的风险,让资源共享变得简单可靠。









