写了一段类似这样的代码:
vector<int> vec;
for (int i = 0; i < 3; i++)
{
vec.push_back(i);
}
int div;
div = -3 / vec.size();
想当然地认为div结果是1?大错特错,其实结果是0x55555554!
问题出在哪里?注意vec.size()
,是unsigned!
所以运算时,先是将-3
转换为了无符号数,再进行除法。如果想要得到-1
的结果,应该这样写:
div = -3 / (int)vec.size();
类似的错误还会发生在<
和>
的比较上:
考虑比较式-1<0U,因为第二个运算数是无符号的,第一个运算数就会被隐式地转换为无符号数,因此表达式就等价于4294967295U<0U,这个答案显然是错误的。
——CSAPP