Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4519429
  • 博文数量: 356
  • 博客积分: 10458
  • 博客等级: 上将
  • 技术积分: 4734
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-24 14:59
文章分类

全部博文(356)

文章存档

2020年(17)

2019年(9)

2018年(26)

2017年(5)

2016年(11)

2015年(20)

2014年(2)

2013年(17)

2012年(15)

2011年(4)

2010年(7)

2009年(14)

2008年(209)

分类: C/C++

2008-06-09 14:44:45

当unsigned遇到int时,隐式转换是怎样的呢?

看如下代码:

#include

int main()
{
    unsigned int a = 1;
    int b = -2;
    printf("a + b = %d\n", a + b);
    printf("is a + b > 0? %d\n", a + b > 0);
    while (1);
}

第一个输出,a + b = -1,           可以理解

第二个输出,a + b > 0 ?   1        为什么?-1不小于0吗?为什么大于0是成立的?

答案出在隐式转换里头,当unsigned类型的a和int类型的b相加时,结果将隐式转换为unsigned类型,

第一个输出结果之所以是-1,是因为我们已经将它的输出格式限定为%d了,所以它被强制转换为int。

而在第二个输出中,a + b 返回的是unsigned,而(unsigned)-1的机器码是0xffffffff(这里默认int为32位),如果用unsined类型来解读这个机器码,那结果将是2^32 -1,比0大得多了,所以a + b > 0 成立。

阅读(3194) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~