写点什么

深入 C++ 常用的三个智能指针

作者:向阳逐梦
  • 2023-07-13
    四川
  • 本文字数:1931 字

    阅读完需:约 6 分钟

深入C++常用的三个智能指针

C++是一门强大的编程语言,但是在内存管理方面却存在着一些问题。手动管理内存不仅费时费力,而且容易出错。因此,C++中引入了智能指针这一概念,以更好地管理内存。

1、什么是智能指针

在 C++中,内存的分配与释放都是由开发者手动进行实现的。虽然说这种方式很灵活,但是也很容易出错,比如说忘记了释放内存或者是释放了已经释放的内存等等。为了避免这样的问题,C++便引入了智能指针这个概念。

智能指针是一种类,它在析构时自动释放所管理的对象所占用的内存。这样,程序员就不需要手动管理内存,减少了出错的可能性。智能指针是一种RAII(Resource Acquisition Is Initialization)技术的应用。

RAII的基本思想是:在对象的构造函数中进行资源的分配,在析构函数中进行资源的释放。智能指针也是这种思想的一种扩展,它在析构时自动释放资源。

2、C++中的几种智能指针

C++中的三种智能指针:unique_ptr、shared_ptrweak_ptr。每种智能指针都有其独特的功能和特点,下面将逐一介绍。

2.1 unique_ptr

unique_ptr是一个独享所有权的智能指针,不能共享所有权。当unique_ptr被销毁时,它所管理的对象的内存也会被自动释放。unique_ptr也可以通过std::move()转移所有权。unique_ptr使用的方法很简单,只需要将所需管理的对象传递给unique_ptr即可。

 #include <iostream> #include <memory>  int main() {     // 使用unique_ptr管理int类型的对象     std::unique_ptr<int> up1(new int(10));     std::cout << "up1: " << *up1 << std::endl;      // 使用make_unique函数创建unique_ptr对象     auto up2 = std::make_unique<int>(20);     std::cout << "up2: " << *up2 << std::endl;      // unique_ptr可以通过std::move()转移所有权     std::unique_ptr<int> up3 = std::move(up1);     std::cout << "up3: " << *up3 << std::endl;      return 0; }
复制代码


2.2 shared_ptr

shared_ptr是一个共享所有权的智能指针,可以有多个shared_ptr指向同一个对象。每当一个shared_ptr被销毁时,它所管理的对象的引用计数会减 1。当引用计数为 0 时,对象的内存也会被自动释放。shared_ptr的使用方法和unique_ptr类似,只需要将所需管理的对象传递给shared_ptr即可。需要注意的是,shared_ptr不能管理动态分配的数组,因为它无法确定数组的长度。

 #include <iostream> #include <memory> int main() {     // 使用shared_ptr管理int类型的对象     std::shared_ptr<int> sp1(new int(10));     std::cout << "sp1: " << *sp1 << std::endl;     // 使用make_shared函数创建shared_ptr对象     auto sp2 = std::make_shared<int>(20);     std::cout << "sp2: " << *sp2 << std::endl;     // 可以有多个shared_ptr指向同一个对象     std::shared_ptr<int> sp3 = sp1;     std::cout << "sp1 count: " << sp1.use_count() << std::endl;     std::cout << "sp3 count: " << sp3.use_count() << std::endl;     return 0; }
复制代码

2.3 weak_ptr


weak_ptr是一个弱引用的智能指针,它可以与shared_ptr一起使用。weak_ptr不会增加所管理的对象的引用计数,因此它不会影响对象的生命周期。可以通过weak_ptrlock()成员函数来获取一个指向所管理的对象的shared_ptr。需要注意的是,在使用lock()函数之前,需要判断weak_ptr是否已经过期,即判断其指向的对象是否已经被销毁。

 #include <iostream> #include <memory> int main() {     // 使用shared_ptr管理int类型的对象     std::shared_ptr<int> sp1(new int(10));     std::weak_ptr<int> wp1 = sp1;     // 判断wp1是否过期     if (auto sp2 = wp1.lock()) {         std::cout << "wp1: " << *sp2 << std::endl;     } else {         std::cout << "wp1 expired" << std::endl;     }     // 销毁sp1     sp1.reset();     // 判断wp1是否过期     if (auto sp2 = wp1.lock()) {         std::cout << "wp1: " << *sp2 << std::endl;     } else {         std::cout << "wp1 expired" << std::endl;     }     return 0; }
复制代码

智能指针是 C++中一种非常实用的内存管理工具。它可以帮助程序员自动管理内存,减少出错的可能性。C++中有三种智能指针:unique_ptrshared_ptrweak_ptr。每种智能指针都有其特点,程序员可以根据实际情况选择使用。

在使用智能指针时,需要注意以下几点:

  • 不要将普通指针和智能指针混用,避免重复释放内存或内存泄漏。

  • 不要将同一个对象交给不同的智能指针管理,避免引用计数出现错误。

  • shared_ptr不能管理动态分配的数组,因为它无法确定数组的长度。

  • 在使用weak_ptrlock()函数之前,需要判断weak_ptr是否已经过期,即判断其指向的对象是否已经被销毁。

发布于: 刚刚阅读数: 7
用户头像

向阳逐梦

关注

人生享受编程,编程造就人生! 2022-06-01 加入

某公司芯片测试工程师,嵌入式开发工程师,InfoQ签约作者,阿里云星级博主,华为云·云享专家。座右铭:向着太阳,追逐梦想!

评论

发布
暂无评论
深入C++常用的三个智能指针_向阳逐梦_InfoQ写作社区