C++中当unsigned和int间的隐式转换

来源:互联网 发布:数据清洗与特征选择 编辑:程序博客网 时间:2024/06/06 15:37

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

看如下代码:
#include <stdio.h>
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 成立。

 

原创粉丝点击