【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()
相关推荐
Tisfy10 分钟前
LeetCode 3650.边反转的最小路径总成本:Dijkstra算法
算法·leetcode··dijkstra·题解·迪杰斯特拉
2401_8384725112 分钟前
自定义操作符重载指南
开发语言·c++·算法
v_for_van15 分钟前
单片机内存分配管理笔记
开发语言·c++·笔记·vscode·stm32·单片机·嵌入式硬件
鹿角片ljp17 分钟前
力扣136.只出现一次的数字-异或和HashMap
java·数据结构·算法·leetcode
W_a_i_T18 分钟前
【Coding日记】菜鸟编程C语言100例——第三题⚠️
c语言·开发语言·经验分享·算法·菜鸟编程
TracyCoder12320 分钟前
LeetCode Hot100(5/100)——11. 盛最多水的容器
算法·leetcode
weixin_4521595520 分钟前
多协议网络库设计
开发语言·c++·算法
十五年专注C++开发21 分钟前
浅谈C++插件机制的设计要点以及实现方案
开发语言·c++·系统架构·插件机制
爱装代码的小瓶子21 分钟前
【C++与Linux基础】文件篇 -语言特性上的文件操作
linux·开发语言·c++
C+-C资深大佬24 分钟前
C++优化
开发语言·c++