【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()
相关推荐
txinyu的博客3 分钟前
结合游戏场景理解,互斥锁,读写锁,自旋锁,CAS / 原子变量,分段锁
开发语言·c++·游戏
Rui_Freely6 分钟前
Vins-Fusion之 SFM准备篇(十二)
人工智能·算法·计算机视觉
hugerat8 分钟前
在AI的帮助下,用C++构造微型http server
linux·c++·人工智能·http·嵌入式·嵌入式linux
-森屿安年-13 分钟前
unordered_map 和 unordered_set 的实现
数据结构·c++·散列表
yyy(十一月限定版)24 分钟前
matlab矩阵的操作
算法·matlab·矩阵
九久。33 分钟前
手动实现std:iterator/std:string/std::vector/std::list/std::map/std:set
c++·stl
小羊羊Python35 分钟前
Sound Maze - 基于 SFML+C++14 的音效迷宫开源游戏 | MIT 协议
c++·游戏·开源
努力学算法的蒟蒻41 分钟前
day58(1.9)——leetcode面试经典150
算法·leetcode·面试
txinyu的博客44 分钟前
HTTP服务实现用户级窗口限流
开发语言·c++·分布式·网络协议·http
代码村新手44 分钟前
C++-类和对象(上)
开发语言·c++