答案:C++智能指针通过RAII管理内存,unique_ptr独占资源、不可复制但可移动,高效安全;shared_ptr共享资源,引用计数控制生命周期,适合多所有者场景。
C++智能指针是用于自动管理动态分配内存的类模板,它们通过RAII(资源获取即初始化)机制确保资源在对象生命周期结束时被正确释放,避免内存泄漏。C++标准库提供了三种主要的智能指针:unique_ptr、shared_ptr 和 weak_ptr。本文重点解析 unique_ptr 与 shared_ptr 的核心用法。
unique_ptr 表示对所指向对象的唯一所有权。同一时间只能有一个 unique_ptr 指向特定资源,当 unique_ptr 被销毁或重置时,其所管理的对象会自动被删除。
特点:
基本用法示例:
#include#include std::unique_ptr ptr1 = std::make_unique (42); // std::unique_ptr ptr2 = ptr1; // 错误:不可拷贝 std::unique_ptr ptr2 = std::move(ptr1); // 正确:移动所有权 if (ptr1 == nullptr) { std::cout << "ptr1 is null\n"; // 输出此行 } if (ptr2) { std::cout << *ptr2 << "\n"; // 输出 42 }
建议使用 std::make_unique 创建对象,它更安全且能避免异常安全问题。
shared_ptr 实现共享所有权,多个 shared_ptr 可以指向同一个对象。它内部使用引用计数来跟踪有多少个 shared_ptr 共享该资源,当最后一个 shared_ptr 被销毁时,对象才会被自动删除。
特点:
基本用法示例:
#include#include auto sp1 = std::make_shared (100); std::shared_ptr sp2 = sp1; // 引用计数变为2 std::cout << "ref count: " << sp1.use_count() << "\n"; // 输出 2 sp1.reset(); // sp1 置空,引用计数减1 std::cout << "ref count after reset: " << sp2.use_count() << "\n"; // 输出 1
推荐使用 std::make_shared 创建 shared_ptr,它能提高性能并保证异常安全。
多数情况下优先使用 unique_ptr,因为它语义清晰、效率高。只有在确实需要共享所有权时才使用 shared_ptr。
常见场景:
基本上就这些。掌握 unique_ptr 和 shared_ptr 的核心差异和使用方式,能显著提升 C++ 程序的
安全性和可维护性。