C++数组定义与操作方法_C++数组初始化与使用教程

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来源,务必手动控制范围。

  • 遍历推荐用范围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_backresize等,适合大小不确定场景
  • 函数接口中优先传递std::span(C++20)或const std::vector&,避免裸指针和长度丢失

基本上就这些。记住:定义看大小、初始化看花括号、访问看边界、扩展看容器。写C++数组,稳比快重要。