C++数组需编译期确定大小且不可变,初始化方式影响默认值,访问须防越界,推荐用std::array或std::vector替代原生数组以提升安全性。

C++数组的定义和使用其实不复杂,但细节容易出错,尤其是初始化方式和边界处理。掌握好基础语法、内存布局和常见操作习惯,能避免很多运行时错误和未定义行为。
一、C++数组的定义与内存特点
数组是连续存储的同类型元素集合,定义时必须指定大小(编译期常量),且大小不可更改。
- 基本语法:int arr[5]; —— 定义含5个int的数组,下标从0到4
- 数组名arr本质是首元素地址(int*类型),但不是指针变量,不能赋值或自增
- 栈上数组大小受限于栈空间;大数组建议用std::vector或堆分配(new int[n])
二、数组初始化的几种方式
初始化时机和写法直接影响元素值,尤其注意“未显式初始化”的情况。
- 全零初始化:int arr[5] = {}; 或 int arr[5] = {0}; —— 所有元素为0
- 部分初始化:int arr[5] = {1, 2}; —— 等效于{1, 2, 0, 0, 0}
- 自动推导大小(C++11起):int arr[] = {1, 2, 3, 4, 5}; —— 编译器算出长度为5
- 局部非静态数组不初始化 → 值为随机垃圾;全局/静态数组默认为0
三、安全访问与常用操作
数组本身不检查下标,越界读写是常见bug来源,务必手动控制范围。
立即学习“C++免费学习笔记(深入)”;
- 遍历推荐用范围for(C++11):for (int& x : arr) { x *= 2; }
- 获取元素个数(仅限原生数组):sizeof(arr) / sizeof(arr[0]),不能用于函数参数中的数组(会退化为指针)
- 传数组给函数时,建议加长度参数:void func(int arr[], size_t n); 或改用std::array
/ std::vector - 禁止用arr[-1]或arr[5]——即使有时“看起来正常”,也是未定义行为
四、替代方案:什么时候该用std::array或std::vector?
原生数组灵活但危险,现代C++更推荐封装容器。
-
std::array
:栈上存储,大小固定,支持.size()、迭代器、范围for,比原生数组更安全易用 -
std::vector
:动态大小,自动管理内存,支持push_back、resize等,适合大小不确定场景 - 函数接口中优先传递std::span
(C++20)或const std::vector & ,避免裸指针和长度丢失
基本上就这些。记住:定义看大小、初始化看花括号、访问看边界、扩展看容器。写C++数组,稳比快重要。










