使用new[]和delete[]可实现c++动态数组,但推荐优先使用std::vector,因其自动管理内存、支持动态扩容且更安全;若需手动控制,可封装类遵循RaiI原则,确保资源正确释放。

在C++中创建和管理动态数组,主要通过指针与堆内存操作实现。相比静态数组,动态数组在程序运行时根据需要分配内存,更加灵活,尤其适用于大小未知或运行中变化的场景。
使用 new 和 delete 创建与释放动态数组
最基本的方法是使用 new[] 在堆上分配内存,用 delete[] 释放内存。
示例:
int size = 10;
int* arr = new int[size]; // 动态创建一个包含10个整数的数组
// 使用数组<br> for (int i = 0; i < size; ++i) {<br> arr[i] = i * 2;<br> }<br><br> // 用完后必须释放<br> delete[] arr;<br> arr = nullptr; // 避免悬空指针
注意:必须使用 delete[] 而不是 delete,否则可能导致未定义行为。
使用 std::vector 替代原生动态数组
C++标准库中的 std::vector 是更安全、更推荐的方式。它自动管理内存,支持动态扩容,并提供丰富的成员函数。
立即学习“C++免费学习笔记(深入)”;
示例:
#include <vector>
std::vector<int> vec(10); // 创建含10个元素的向量<br> vec[0] = 100;<br><br> // 或者动态添加元素<br> vec.push_back(200); // 自动扩容<br><br> // 不需要手动释放,离开作用域自动清理
优点:避免内存泄漏、边界检查(可选)、自动扩容、兼容STL算法。
封装原生动态数组(进阶:自定义类)
若需完全控制内存管理,可封装一个类来管理动态数组。
简单示例:
class DynamicArray {
private:
int* data;
int size;
public:<br> DynamicArray(int s) : size(s) {<br> data = new int[size];<br> }<br><br> ~DynamicArray() {<br> delete[] data;<br> }<br><br> int& operator[](int index) { return data[index]; }<br> };
此类遵循RAII原则,在析构时自动释放内存,避免资源泄露。
基本上就这些。优先使用 std::vector,只有在性能敏感或特殊需求下才直接操作 new/delete。正确管理内存是关键,避免泄漏和重复释放。