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来源,务必手动控制范围。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~