无符号整型与有符号整型的比较

喵哥最近遇到一个问题,比较两个数的时候经常会出现很严重的bug,比如:

unsigned int a = 0;
int b = -2;
if (a < b)
	b = 1;
cout << b << endl;

乍一看这段代码输出的应该是-2,0肯定不会小于-2嘛,但是事实上,“b = 1;”这行代码是会被执行的。如果大家对算术转换比较熟悉的话,应该会想到这应该是发生了“整型提升”——int提升为unsigned int。其实大家感到困惑的一个重要原因是:书本给的例子大多数都是加减乘除时整型提升,让人很惯性地认为只有进行算术运算的时候才会发生转换。事实上,这些类型的转变发生在所有双目运算符执行的时候(双目运算符的两个运算对象类型不一样)。那么自然而然地,在“<”等这类运算符执行时会对运算对象进行类型转换。

为了直观地表示这种转换,喵哥把代码的汇编贴出来:

在汇编中,b的值临时放在eax中,在执行到(a<b)的时候,b的值(即eax)变为了4294967294(unsigned int),这个数显然是大于0的,故而条件为真,执行b = 1;。

如果把a的值改为4294967295,即unsigned int的最大值,则条件会为false。

再如:

string str = "hello";
int pos = str.find('a');
string::size_type n = string::npos;
if (pos == n)
	cout << "no";

string::npos的值是unsigned long long的最大值18446744073709551615,即long long的-1,在比较pos与n时,pos的类型会自动提升为unsigned long long。

通常,认为string::npos等于-1就好了。

 

 

 

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值