【C++】bug之vector subscript out of range

vector subscript out of range 是指vector下标越界,一般都是遍历下标出错导致越界访问。一般情况是手一滑就把循环边界写错。当然也有出乎意料的出错地方。

对vector进行遍历的时候经常这么写

复制代码
vector<int>a;
//a.push_back(2);
//...
for(int i=0;i<a.size();i++)
{
	//a[i]
}

这里注意一点,a.size()是一个无符号整数,更加规范的写法是把i定义为size_t类型,也就是无符号整数。


出乎意料的情况
复制代码
for( size_t i = 0; i <= v.size()-1; i++)  
{  
        cout<<v[i]<<endl;  
}  

若v.size()=0,也会出现下标越界,因为size是无符号整数,执行0-1,则此时二进制位全为1,代表无符号数能表达的最大值UMax,则其值为 2 32 − 1 2^{32}-1 232−1,而小于等于符号同样使用无符号数比较,任何数都是小于或者等于Umax的,该比较总是为真,则会出现下标越界访问,当然一般size里不会等于0,但是若是出现在不停迭代变化的场景下如此写必然会出现错误。

预防方法:
  1. 要么将length声明为int 2. 要么将for循环测试条件改成i < size()
相关推荐
Chan162 分钟前
LeetCode 热题 100 | 链表
java·数据结构·spring boot·算法·leetcode·链表·java-ee
程序员小明儿3 分钟前
量子计算探秘:从零开始的量子编程与算法之旅 · 第五篇
算法·量子计算
灰色小旋风4 分钟前
力扣第九题C++回文数
c++·算法·leetcode
vx-bot55566620 分钟前
企业微信ipad协议的增量同步算法与差量更新机制
算法·企业微信·ipad
悦心无谓22 分钟前
C++负载均衡式在线OJ测试报告
开发语言·c++·selenium·测试工具·负载均衡·编程语言·后端开发
不想写代码的星星22 分钟前
C++引用的“三重门”:左值、右值、万能引用,你真的懂了吗?
c++
小温冲冲23 分钟前
Qt进阶:高级渲染与界面定制完全指南(新手友好版)
c++·qt
cpp_250124 分钟前
P1359 租用游艇
c++·算法·题解·洛谷·线性dp
Naisu Xu27 分钟前
数学笔记:最小二乘法(直线拟合)
笔记·算法·最小二乘法
weixin_3954489129 分钟前
main.c_raw_0311_lyp
前端·网络·算法