new用于在堆上分配内存并调用构造函数,delete用于释放内存;正确使用可确保动态内存安全高效管理。

在C++中,new和delete是用于动态内存管理的关键操作符。它们允许程序在运行时从堆(heap)上分配和释放内存,而不是在栈上静态或自动分配。掌握它们的正确用法,对编写高效、安全的C++代码至关重要。
new的基本用法
使用new可以在堆上为单个对象或对象数组分配内存,并自动调用构造函数。
分配单个对象:
int* p = new int; // 分配一个int类型的内存
*p = 10;
int* q = new int(42); // 分配并初始化为42
分配对象数组:
立即学习“C++免费学习笔记(深入)”;
int* arr = new int[10]; // 分配10个int的数组
for (int i = 0; i arr[i] = i * 2;
}
对于类类型,new会自动调用构造函数:
class MyClass {
public:
MyClass() { cout };
MyClass* obj = new MyClass; // 调用构造函数
MyClass* objArray = new MyClass[5]; // 创建5个对象,每个都调用构造函数
delete的正确匹配方式
每次使用new分配的内存,必须使用对应的delete释放,否则会导致内存泄漏。
释放单个对象:
int* p = new int(100);
// … 使用p
delete p; // 正确:释放单个对象
释放数组对象:
int* arr = new int[10];
// … 使用arr
delete[] arr; // 注意:必须用 delete[] 释放数组
如果对数组使用了delete而非delete[],行为是未定义的,可能导致程序崩溃或资源未完全释放。
对于类对象,delete会自动调用析构函数:
MyClass* obj = new MyClass;
delete obj; // 自动调用析构函数
MyClass* objs = new MyClass[3];
delete[] objs; // 每个对象的析构函数都会被调用
常见错误与注意事项
使用new和delete时容易犯以下错误,应特别注意:
重复释放同一指针:delete之后不应再次delete同一个指针释放未由new分配的内存:例如栈上的变量地址不能delete混用new/delete与new[]/delete[]:必须严格匹配忘记释放内存:造成内存泄漏,长期运行的程序尤其危险使用已释放的指针:delete后建议将指针设为nullptr
示例:
int* p = new int(50);
delete p;
p = nullptr; // 避免悬空指针
现代C++中的替代方案
虽然new和delete在底层控制中仍有用途,但现代C++更推荐使用智能指针和容器来管理内存,避免手动管理带来的风险。
std::unique_ptr:独占所有权的智能指针,自动释放内存std::shared_ptr:共享所有权,引用计数管理生命周期std::vector:替代动态数组,自动管理内存
例如:
#include
#include
auto p = std::make_unique(42); // 自动释放
std::vector vec(10); // 替代 new int[10]
基本上就这些。new和delete要慎用,优先考虑RAII和智能指针,才能写出更安全、可维护的C++代码。
以上就是c++++中new和delete的正确用法_c++动态内存管理操作详解的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1479885.html
微信扫一扫
支付宝扫一扫