数组越界是C++新手常见错误,因下标从0开始而误用1到n范围,导致运行时崩溃或数据错乱;合法下标为0到n-1。

数组越界是C++新手最常遇到、也最容易被忽略的错误之一。它不会总在编译时报错,但运行时可能引发崩溃、数据错乱或难以复现的诡异行为——因为越界访问的是未授权内存,结果完全不可预测。
下标从0开始,但常被当成从1开始用
C++数组索引严格从0开始,长度为n的数组合法下标是0 到 n-1。新手容易误以为下标范围是1到n,导致循环多跑一次或少跑一次。
- 错误写法:
for (int i = 1; i (对大小为5的数组,i=5已越界) - 正确写法:
for (int i = 0; i - 建议:养成写
i 的习惯,而不是i ,更直观也不易算错
忘记检查输入或计算后的下标是否有效
用户输入、随机数、字符串长度、容器size()等动态值,直接当数组下标用前必须验证。
- 常见陷阱:
string s = "abc"; char c = s[5];—— string的[]不检查边界,越界后行为未定义 - 更安全的选择:
s.at(5)会抛出std::out_of_range异常,便于调试 - 对C风格数组,务必先判断:
if (idx >= 0 && idx
混淆数组长度与字符串长度
字符数组和C风格字符串(以'
字符数组和C风格字符串(以'\0'结尾)长度概念不同,新手常把两者混为一谈。
'结尾)长度概念不同,新手常把两者混为一谈。立即学习“C++免费学习笔记(深入)”;
- 例如:
char name[10] = "Tom";,数组长度是10,但字符串长度(strlen(name))是3 - 错误:用
for (int i = 0; i 会输出乱码(后面7个字节未初始化) - 正确:遍历到
'\0'为止,或用std::string替代,自动管理长度和边界
使用vector却仍手写越界逻辑
改用std::vector能大幅降低风险,但如果不注意接口差异,照样会越界。
-
vec[i]和数组一样不检查边界;vec.at(i)才做范围检查 -
vec.size()返回当前元素个数,不是容量;vec.capacity()才是分配的内存大小,别拿它当下标上限 - 插入后记得确认size:
vec.push_back(x); if (!vec.empty()) use(vec[vec.size()-1]);
基本上就这些。越界问题不复杂,但容易忽略——关键是在每次访问前,心里默念一句:“这个下标真的在合法范围内吗?”










