当前位置: 首页 > news >正文

C++智能指针用法及内存管理

一、内存管理中最长出现的问题:

1、空指针空指针是一个不指向任何有效对象或函数的指针,其值为 NULL(C)或 nullptr(C++11 起)

2、野指针野指针是指指向“不可用”或“无效”内存地址的指针,指向一个未知地方

int* ptr;  // 未初始化,ptr 是野指针
*ptr = 10; // 危险操作,访问非法地址int* ptr = malloc(sizeof(int));
free(ptr);
*ptr = 20; // ptr 成为野指针(悬空指针)int* func() {int x = 10;return &x;  // 返回局部变量地址,函数结束后栈内存被释放,成为野指针
}

二、内存管理的方法

1、aoto(变量类型)

在 C++11 中,auto 关键字允许编译器根据变量的初始化表达式自动推导其类型,从而简化代码编写,尤其是在使用复杂类型时非常方便。使用场景通常有以下几个:

1、搭配STL容器使用

#include <vector>
std::vector<int> vec = {1, 2, 3};for (auto it = vec.begin(); it != vec.end(); ++it) {std::cout << *it << " ";
}

2、搭配智能指针使用

#include <memory>auto ptr = std::make_shared<int>(42);   // shared_ptr<int>
auto uptr = std::make_unique<std::string>("hello");  // unique_ptr<string>

2、智能指针(内存申请)

C++ 中的 智能指针 是用于自动管理动态内存的类模板,它们通过封装裸指针(raw pointer),在对象生命周期结束时自动释放资源,从而避免内存泄漏和悬空指针等问题。最常用的智能指针如下,使用场景如下:

  • 需要唯一控制资源时 → 使用 std::unique_ptr
  • 多个对象共享资源时 → 使用 std::shared_ptr

std::unique_ptr:同一时间只能有一个 unique_ptr 指向一个对象,使用make_unique创建一个对象。

std::shared_ptr:多个 shared_ptr 可以指向同一个对象,使用make_shared创建一个对象。

std::weak_ptr:不拥有对象,只是观察由 shared_ptr 管理的对象。

通过reset()函数可以手动释放资源,离开作用域以后也会自动释放资源

#include <memory>std::unique_ptr<int> ptr1 = std::make_unique<int>(42);
// std::unique_ptr<int> ptr2 = ptr1; // 编译错误:不可复制
std::unique_ptr<int> ptr2 = std::move(ptr1); // 合法:移动所有权std::shared_ptr<int> ptr1 = std::make_shared<int>(42);
std::shared_ptr<int> ptr2 = ptr1;  // 合法:共享所有权
std::cout << "Use count: " << ptr1.use_count() << std::endl;  // 输出 2ptr1.reset(); // 释放内存,ptr 变为 nullptr

3、NEW操作符(内存申请)

new 是一个用于动态分配内存的操作符,用于向堆去申请内存空间,它分配内存的大小由其后跟的数据类型决定。如,int* ptr = new int; 这行代码会在堆上分配一个能够存储一个整数的内存空间,并返回该内存块的首地址,将其赋值给指针 ptr。释放的时候需要调用delete ptr;去手动释放内存

int* p = new int;           // 分配一个未初始化的 int
int* p2 = new int(42);      // 分配并初始化为 42
delete p;
delete p2;

4、molloc(c语言内存申请)

分配指定大小(字节)的内存块,不初始化,需要手动管理内存

#include <stdlib.h>int* ptr = (int*)malloc(5 * sizeof(int));  // 分配能存储 5 个 int 的内存
if (ptr == NULL) {// 处理内存分配失败printf("Memory allocation failed\n");exit(EXIT_FAILURE);
}free(ptr);   // 释放后 ptr 成为“悬空指针”
ptr = NULL;  // 建议置为 NULL,防止后续误用

http://www.xdnf.cn/news/690769.html

相关文章:

  • 双因子COX 交互 共线性 -spss
  • 多态 向上转型
  • YOLO人体姿态估计Pytorch推理ONNX模型推理
  • Android-GestureDetector学习总结
  • 微信小程序(uniapp)对接腾讯云IM
  • Vue 实例生命周期
  • 2025.5.28总结
  • 接口幂等性原理与方案总结
  • Avue表单个别字段实现全选的思路
  • 【Pandas】pandas DataFrame drop
  • Transformer核心技术解析LCPO方法:精准控制推理长度的新突破
  • Redis学习(十四)主从复制的工作原理、集群搭建(一主二从)
  • Android 云手机横屏模式下真机键盘遮挡输入框问题处理
  • [AD] Noxious LLMNR+DHCP+NTLMv2+Kerberos+SMB
  • 高精度导航 | RTK:2025年高精度导航算法综述,包括:原理,数据,公式,完整代码,开源代码链接
  • 网络协议之办公室网络是怎样的?
  • Mac M1编译OpenCV获取libopencv_java490.dylib文件
  • xcode 旧版本、历史版本下载
  • 【C/C++】高性能网络编程之Reactor模型
  • 网站缓存入门与实战:浏览器与Nginx/Apache服务器端缓存,让网站速度起飞!(2025)
  • git配置(1): 根据remote自动选择账号执行commit
  • MCU - SPI总线介绍 + W25Qx驱动设计
  • node-DeepResearch开源ai程序用于深入调查查询,继续搜索、阅读网页、推理,直到找到答案
  • SpringBoot项目快速打包与部署,War包⽅式打包部署与Jar包⽅式打包部署两种方式
  • 迁移学习模型构建指南(Python实现)
  • 云服务器系统盘满了,但是其他正常,是否可能是被攻击了
  • electron开发百度桌面应用demo及如何打包应用
  • SpringBoot 执行Lua脚本 服务端执行 减少性能损耗 优化性能 优化连接性能
  • linux使用服务添加一个开机启动脚本
  • 同一机器下通过HTTP域名访问其他服务器进程返回504问题记录