C++11引入智能指针解决内存管理问题,unique_ptr独占所有权并自动释放资源,shared_ptr通过引用计数实现共享所有权,weak_ptr打破循环引用,推荐使用make_unique和make_shared创建智能指针以提升安全性。

在 C++ 中,手动管理内存容易引发内存泄漏、重复释放等问题。为了解决这些问题,C++11 引入了智能指针,主要包括 std::unique_ptr 和 std::shared_ptr,它们能自动管理动态分配的对象生命周期,确保资源安全释放。
std::unique_ptr 表示对对象的独占所有权,同一时间只能有一个 unique_ptr 指向某个对象。当 unique_ptr 被销毁时,它所管理的对象也会被自动删除。
使用场景:当你需要动态分配对象且不希望多个指针共享该对象时,应优先使用 unique_ptr。
基本用法:
立即学习“C++免费学习笔记(深入)”;
#include <memory>
#include <iostream>
int main() {
auto ptr = std::make_unique<int>(42);
std::cout << *ptr << "\n"; // 输出 42
// 移动所有权
auto ptr2 = std::move(ptr);
// 此时 ptr 为空,ptr2 拥有对象
return 0;
} // ptr2 离开作用域,自动 delete
std::shared_ptr 实现引用计数机制,多个 shared_ptr 可以共享同一个对象。只有当最后一个 shared_ptr 被销毁时,对象才会被释放。
使用场景:多个模块或函数需要共享同一个对象时使用。
基本用法:
立即学习“C++免费学习笔记(深入)”;
#include <memory>
#include <iostream>
void use_ptr(std::shared_ptr<int> p) {
std::cout << "引用计数: " << p.use_count() << "\n";
}
int main() {
auto sptr = std::make_shared<int>(100);
std::cout << "初始引用计数: " << sptr.use_count() << "\n";
{
auto sptr2 = sptr; // 引用计数 +1
std::cout << "复制后引用计数: " << sptr.use_count() << "\n";
use_ptr(sptr2); // 再次增加临时引用
} // sptr2 销毁,引用计数 -1
return 0;
} // sptr 销毁,引用计数归零,释放内存
当两个 shared_ptr 相互持有对方时,会导致引用计数无法归零,形成内存泄漏。这时应使用 std::weak_ptr 打破循环。
weak_ptr 不增加引用计数,只是一个“观察者”,访问前需检查对象是否还存在。
#include <memory>
struct Node {
std::shared_ptr<Node> parent;
std::weak_ptr<Node> child; // 避免循环引用
};
auto node1 = std::make_shared<Node>();
auto node2 = std::make_shared<Node>();
node1->child = node2;
node2->parent = node1; // 形成父子关系,但 child 是 weak_ptr
// 正常析构,不会泄漏
基本上就这些。合理使用 unique_ptr 和 shared_ptr,配合 make_unique / make_shared,能极大提升代码安全性与可维护性。注意避免裸 new/delete,优先让智能指针接管资源管理。
以上就是C++ 如何使用智能指针 (shared_ptr, unique_ptr)_C++ 智能指针用法与内存管理的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号