new 运算符是 c++++ 中用于动态分配内存的关键字,它在程序运行时根据需要在堆上申请内存空间。new 的基本作用是为变量或对象分配内存,并返回指向该内存的指针,例如 int p = new int; 用于分配单个整型变量,int arr = new int[10]; 用于分配长度为10的整型数组。使用 new 分配内存后必须手动释放:delete 用于单个对象,delete[] 用于数组。注意事项包括:1. 必须检查分配是否成功,可用 new (std::nothrow) 避免异常;2. 不得重复释放同一块内存;3. 动态内存常用于实现数据结构,需注意深拷贝问题;4. 推荐使用智能指针如 std::unique_ptr 和 std::shared_ptr 自动管理内存,避免内存泄漏。

动态分配内存其实就是让程序在运行时根据需要申请一定大小的内存空间,而不是在编译时就固定下来。C++中常用的方法之一就是使用 new 运算符来实现这一点。相比静态分配,动态分配更灵活,尤其适合处理不确定数据量的场景。

什么是 new 运算符?
new 是 C++ 中用于动态分配内存的关键字。它的基本作用是在堆(heap)上为某个变量或对象分配内存,并返回指向该内存的指针。

比如:
int* p = new int;
这行代码的意思是:在堆上分配一个 int 类型大小的内存空间,并将这个地址赋值给指针 p。这时候你就可以通过 *p = 10; 给这块内存赋值了。

如果要分配数组,写法略有不同:
int* arr = new int[10];
这就相当于分配了一个长度为10的整型数组。
动态内存分配的注意事项
使用 new 虽然方便,但有几个关键点需要注意:
-
记得释放内存:用完之后必须手动调用
delete或delete[]来释放内存,否则会造成内存泄漏。- 单个对象用
delete p; - 数组则要用
delete[] arr;
- 单个对象用
-
检查是否分配成功:虽然现代系统很少出现内存不足的情况,但在嵌入式设备或资源紧张的情况下,
new可能失败并抛出异常(默认情况下)。可以使用nothrow版本避免异常:int* p = new (std::nothrow) int; if (!p) { // 内存分配失败的处理逻辑 } 不要重复释放同一块内存:对同一个指针多次调用
delete是未定义行为,可能会导致程序崩溃。
实际应用中的常见模式
在实际开发中,动态内存通常配合指针和类一起使用,尤其是在实现数据结构(如链表、树、图等)时特别常见。
举个例子,假设你要实现一个简单的动态数组类:
class DynamicArray {
private:
int* data;
int size;
public:
DynamicArray(int s) {
size = s;
data = new int[size];
}
~DynamicArray() {
delete[] data;
}
// 其他操作...
};这种写法需要注意深拷贝问题,否则两个对象可能共享同一块内存,造成重复释放的问题。所以如果你写了构造函数分配了内存,最好也自定义拷贝构造函数和赋值运算符。
小技巧:别忘了智能指针
虽然 new 和 delete 是手动管理内存的基本手段,但现代 C++ 更推荐使用智能指针(如 std::unique_ptr 和 std::shared_ptr),它们可以在对象生命周期结束时自动释放内存,有效避免内存泄漏。
例如:
#includestd::unique_ptr p(new int);
这样就不需要手动调用 delete 了,出了作用域会自动清理。
基本上就这些。用 new 分配内存不复杂,但容易忽略的是后续的释放和异常处理。只要养成良好的习惯,比如“谁分配谁释放”、“优先用智能指针”,就能大大减少出错的概率。










