std::shared_ptr通过引用计数自动管理内存,避免泄漏;推荐用std::make_shared创建,注意循环引用问题并用std::weak_ptr解决。

在C++开发中,内存泄漏是一个常见且棘手的问题。手动管理动态内存时,容易因忘记释放或异常导致资源未回收。为解决这一问题,C++11引入了智能指针,其中 std::shared_ptr 是最常用的工具之一。它通过引用计数机制自动管理对象生命周期,有效避免内存泄漏。
std::shared_ptr 是一种共享所有权的智能指针。多个 shared_ptr 可以指向同一个对象,当最后一个 shared_ptr 被销毁或重置时,所管理的对象会自动被删除。
其核心机制是引用计数:每增加一个 shared_ptr 指向该对象,计数加1;减少一个则减1。计数为0时,对象被释放。
示例:#include <memory>
#include <iostream>
int main() {
std::shared_ptr<int> ptr1 = std::make_shared<int>(42);
std::cout << "引用计数: " << ptr1.use_count() << "\n"; // 输出 1
{
std::shared_ptr<int> ptr2 = ptr1;
std::cout << "引用计数: " << ptr1.use_count() << "\n"; // 输出 2
} // ptr2 离开作用域,计数减1
std::cout << "引用计数: " << ptr1.use_count() << "\n"; // 输出 1
return 0;
} // ptr1 销毁,对象自动 delete
推荐使用 std::make_shared 而非直接 new,原因包括性能更好(一次内存分配)和异常安全。
立即学习“C++免费学习笔记(深入)”;
auto obj = std::make_shared<MyClass>("hello", 100);
std::shared_ptr<MyClass> ptr(new MyClass("hello")); // 可能引发异常安全问题
适用于需要多个所有者共享同一资源的场合。
std::shared_ptr<DataBuffer> buffer = std::make_shared<DataBuffer>(1024); network_module.process(buffer); log_module.cache(buffer); // 两个模块共享同一份数据
shared_ptr 的最大陷阱是循环引用:两个对象互相持有对方的 shared_ptr,导致引用计数永不归零。
错误示例:struct Node {
std::shared_ptr<Node> parent;
std::shared_ptr<Node> child;
};
// 若 parent.child 和 child.parent 同时指向对方,则无法释放
解决方案:使用 std::weak_ptr 打破循环。weak_ptr 不增加引用计数,仅观察对象是否存在。
修正后:struct Node {
std::weak_ptr<Node> parent; // 改用 weak_ptr
std::shared_ptr<Node> child;
};
访问 weak_ptr 前需调用 lock() 获取临时 shared_ptr:
if (auto p = parent.lock()) {
p->do_something();
} else {
// 对象已释放
}
shared_ptr 可以像普通指针一样使用成员访问操作符。
不要将 shared_ptr.get() 返回的原始指针再用于构造新的 shared_ptr,会导致重复 delete。
基本上就这些。合理使用 shared_ptr 能大幅降低内存泄漏风险,但需警惕循环引用。搭配 weak_ptr 使用,可构建安全高效的资源管理体系。以上就是C++智能指针shared_ptr用法详解_C++内存泄漏解决方案的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号