C++中智能指针是如何工作的?

C++中的智能指针是基于**RAII(Resource Acquisition Is Initialization)**理念设计的自动化内存管理工具,通过对象生命周期管理资源。以下是三种核心智能指针的工作原理:


1. std::unique_ptr(独占所有权)

  • 核心机制:通过移动语义(Move Semantics)确保资源仅有一个所有者。

  • 所有权转移

    cpp 复制代码
    std::unique_ptr<int> ptr1 = std::make_unique<int>(10);
    std::unique_ptr<int> ptr2 = std::move(ptr1); // ptr1 释放所有权
  • 资源释放 :当unique_ptr离开作用域时,自动调用析构函数并释放内存。


2. std::shared_ptr(共享所有权)

  • 引用计数

    • 每个shared_ptr内部维护一个控制块(包含引用计数器和弱计数器)。
    • 复制时引用计数递增:$$ \text{ref_count} \leftarrow \text{ref_count} + 1 $$
    • 析构时递减:$$ \text{ref_count} \leftarrow \text{ref_count} - 1 $$
    • 当$$ \text{ref_count} = 0 $$时释放资源。
  • 示例

    cpp 复制代码
    auto p1 = std::make_shared<int>(20); // 引用计数=1
    {
      auto p2 = p1; // 引用计数=2
    } // p2析构,引用计数=1
    ``` // p1析构,引用计数=0,释放内存

3. std::weak_ptr(观察所有权)

  • 解决循环引用 :不增加引用计数,需通过lock()转为shared_ptr访问资源:

    cpp 复制代码
    std::weak_ptr<int> w_ptr;
    {
      auto s_ptr = std::make_shared<int>(30);
      w_ptr = s_ptr; // 不增加引用计数
    }
    if (auto tmp = w_ptr.lock()) { // 资源已释放,tmp为空
      // 操作资源
    }
    点击并拖拽以移动

关键操作对比

操作 unique_ptr shared_ptr weak_ptr
所有权独占
允许多引用
可直接访问资源 ✗¹
自动释放(零引用)

¹需通过lock()转为shared_ptr后访问


应用场景

  • unique_ptr:工厂模式返回对象、独占资源管理。
  • shared_ptr + weak_ptr:缓存系统、观察者模式。
  • 避免使用auto_ptr(C++17废弃,所有权转移不安全)。

智能指针通过自动化生命周期管理,显著降低了内存泄漏和悬垂指针的风险。

相关推荐
之歆7 小时前
Spring AI入门到实战到原理源码-MCP
java·人工智能·spring
yangminlei7 小时前
Spring Boot3集成LiteFlow!轻松实现业务流程编排
java·spring boot·后端
qq_318121597 小时前
互联网大厂Java面试故事:从Spring Boot到微服务架构的技术挑战与解答
java·spring boot·redis·spring cloud·微服务·面试·内容社区
txinyu的博客7 小时前
解析业务层的key冲突问题
开发语言·c++·分布式
J_liaty7 小时前
Spring Boot整合Nacos:从入门到精通
java·spring boot·后端·nacos
阿蒙Amon8 小时前
C#每日面试题-Array和ArrayList的区别
java·开发语言·c#
daidaidaiyu8 小时前
Spring IOC 源码学习 一文学习完整的加载流程
java·spring
SmartRadio9 小时前
ESP32添加修改蓝牙名称和获取蓝牙连接状态的AT命令-完整UART BLE服务功能后的完整`main.c`代码
c语言·开发语言·c++·esp32·ble
2***d8859 小时前
SpringBoot 集成 Activiti 7 工作流引擎
java·spring boot·后端
五阿哥永琪9 小时前
Spring中的定时任务怎么用?
java·后端·spring