智能指针是一种 C++ 类型,它能够自动管理其所指向的对象的内存。它通常使用 RAII 技术(资源获取即初始化)来确保在离开作用域时,所指向的对象被正确地销毁。
C++ 标准库提供了两种智能指针:std::unique_ptr 和 std::shared_ptr。
std::unique_ptr 是一种独占式智能指针,它拥有对其所指向对象的唯一所有权。当 std::unique_ptr 被销毁时,它所指向的对象也会被销毁。由于其独占性,std::unique_ptr 不能被拷贝,只能被移动。
std::shared_ptr 是一种共享式智能指针,它可以被多个指针共享。每个指针都维护一个引用计数,当引用计数为 0 时,所指向的对象会被销毁。std::shared_ptr 可以被拷贝和移动。
下面是一个使用智能指针的C++示例:
#include <iostream>
#include <memory>
int main() {
std::unique_ptr<int> myPtr = std::make_unique<int>(42);
std::cout << *myPtr << std::endl; // 输出 42
// 使用智能指针释放内存,避免内存泄漏
myPtr.reset();
// 尝试访问已经释放的内存会导致运行时错误(segmentation fault)
// std::cout << *myPtr << std::endl;
std::shared_ptr<int> sharedPtr1 = std::make_shared<int>(10);
std::shared_ptr<int> sharedPtr2 = sharedPtr1;
std::cout << *sharedPtr1 << std::endl; // 输出 10
std::cout << *sharedPtr2 << std::endl; // 输出 10
// 使用智能指针自动管理内存,不需要手动释放
// 智能指针会自动更新引用计数
sharedPtr1.reset();
// 只有当所有引用都被释放后,内存才会被自动释放
std::cout << "sharedPtr2 use count: " << sharedPtr2.use_count() << std::endl; // 输出 1
}
在这个示例中,我们使用了 std::unique_ptr
和 std::shared_ptr
来管理动态分配的内存。在第一个示例中,我们使用 std::unique_ptr
来创建一个指向 int
类型的指针,并且使用 std::make_unique
函数来分配内存并初始化内存中的值为 42
。然后我们通过解引用智能指针来输出值,并使用 reset
方法来释放内存,避免内存泄漏。
在第二个示例中,我们使用 std::shared_ptr
来管理内存。我们使用 std::make_shared
函数来分配内存和初始化其中的值为 10
。然后我们创建另一个智能指针 sharedPtr2
并将其绑定到同一块内存上,这样就有两个指针引用了同一块内存。最后我们使用 reset
方法来释放 sharedPtr1
中的指针。由于 sharedPtr2
仍然引用该内存块,因此内存不会被释放。我们可以使用 use_count
方法来查看当前有多少个智能指针引用了该内存块。