百度空间 | 百度首页 
 
查看文章
 
C++中当unsigned和int间的隐式转换
2008年03月05日 星期三 上午 00:57

当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 成立。


类别:软件设计 | 分享到i贴吧 | 浏览() | 评论 (0)
 
最近读者:
 
网友评论:
发表评论:
姓 名:
网址或邮箱: (选填)
内 容:
验证码: 请点击后输入四位验证码,字母不区分大小写
      

     

©2009 Baidu