【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()
相关推荐
njsgcs1 分钟前
c# solidworks createline 拉伸发现有微小两点间隙 导致拉伸变成薄壁特征 改bug画了6个小时 解决结果
c#·bug·solidworks
小许同学记录成长1 分钟前
三维编辑功能实现
qt·算法·无人机
平行侠1 分钟前
026FFT快速乘法 - 从信号处理到大数计算的革命
数据结构·算法·信号处理
gqk011 分钟前
C++ / MFC / Qt / C# 核心知识点汇总笔记
c++·qt·mfc
Controller-Inversion7 分钟前
240. 搜索二维矩阵 II
线性代数·算法·矩阵
计算机安禾10 分钟前
【c++面向对象编程】第4篇:类与对象(三):拷贝构造函数与深浅拷贝问题
开发语言·c++·算法
j_xxx404_11 分钟前
Linux共享内存原理与实战:从内核到C++实现|附源码
linux·运维·开发语言·c++·人工智能
C雨后彩虹12 分钟前
猴子爬山问题
java·数据结构·算法·华为·面试
y = xⁿ13 分钟前
20天速通LeetCodeday13:关于回溯
算法
前端达人13 分钟前
第18课:实战案例二,线上紧急 Bug 修复全过程
bug