一般vector类型的size()函数返回的是一个uint类型整数,一般情况下我都是直接当做int一样使用,但是有一点容易出错,就是int与uint类型的比较。int与uint比较时应该是会把int转换成uint,因为uint无符号,所以如果一个负的int转换成uint会溢出,所以比较大小时会出现违背直觉的结果,如:
#include <iostream>
using namespace std;
int main(int, char**) {
cout<<"compare int and uint:"<<endl;
int a=-1;
uint b=1000;
cout<<"int(-1) > uint(1000)?=>"<<(a>b)<<endl;
}
结果是:
这里int型-1变成uint,因为溢出变成了最大的uint,反而比一个正数更大
另外一个比较易错的场景是在循环中,比如双重循环比较每个元素与其之后元素:
for(int i=0;i<vec.size()-1;++i){
//vec是一个vector,这里可能会陷入死循环,比如如果vec.size()==0,因为size()返回的是uint,
//uint型的0减1会向下溢出变成最大的uint,而i是int型,永远比最大的uint小
//(除非增加到向上溢出然后自增到-1)
for(int j=i+1;j<vec.size();++j){
//do some cool stuff here
}
}