问题源于一天在群里看到别人问的一个问题:
题目1:
unsigned int a = -1;
char b = -1;
printf("%d\n",a==b);
输出:?
题目2:
unsigned short a = -1;
char b = -1;
printf("%d\n",a==b);
输出:?
总有些人不加思索的说,这么简单的题,肯定不会相等了。咋一看,确实应该不会相等呀,而且两个题目都应该是a>b吧。
分析:
题目1:执行第一条语句后,将-1强制转换成整形赋值给a,对与32位的系统且int类型占4 Bytes的编译器来说,我们知道在内存中数都是以补码的形式存储的,-1的补码(32位)为32个1,其对应的无符号数即为2的32次方-1。所以执行完第一条语句后a=4 294 967 295。
执行完第二条语句后,b的值还是-1,但是当执行第三条语句的时候,一个unsigned int类型和一个char类型比较,编译器会将他们全部变成unsigned int 类型,这样b也就会变为4 294 967 295。所以a就等于b了。
题目2:好,有些人说,第二题那肯定也相等了,因为执行完第一条语句后,将-1转换成unsigned short类型,对于32位系统,其一般占2 Bytes,所以此时a 为2的16次方-1即为65535,同样比较的时候,b肯定会转换成unsigned short类型,所以a等于b。但是,当我们真正在机子上跑下这个代码,会发现其实,a是大于b,这是为什么呢?其实,在比较的时候,并不是把b转换成unsigned short类型,而是都转换成int类型,再比较的。a转换成int类型还是65535,b也还是-1,所以a是大于b。
总结一点:
① :只要有unsigned int 类型参与比较,将两个比较数全部转换成unsigned int 类型后,再做比较。
② :没有unsigned int 类型参与比较的,将两个比较数全部转换成int类型(不论比较数为何种类型)后,再做比较。
注意:上面只针对整形数了。
好了,根据上面的总结看看下面代码输出什么吧。
思考题1:
unsigned char a = -1;
char b = -1;
printf("%d\n",a>b);
思考题2:
int a = -1;
unsigned int b = 1;
printf("%d\n",a>b);
本文下载地址:http://pan.baidu.com/share/link?shareid=1591091186&uk=4213349809