首先给一段代码
1 #include <stdio.h>
2 int main()
3 {unsigned int x=9;
4 int y=-20;
5 int m=(x+y>9)?1:0;
6 int z=x+y;
7 printf("%d\n",m);
8 printf("%d\n",z);
9 if(y>x)
10 {
11 printf("?????\n");
12 }
13 }
每一行的第一个数字是行号
在第五行,如果大意的话,就会认为输出的是m=0;
然而并不是这个结果,在计算机中,所有的运算都是补码运算
00000000 00000000 00000000 00001001
+00000000 00000000 00000000 11101100
=00000000 00000000 00000000 11110101
如果只看低8位,如果把这8位当做是一个无符号数来看待的话
11110101=245
如果把这8位当做是一个有符号数来看待的话
11110101=-11.
这个时候,编译器会根据要计算的数据类型自动决定这些二进制代码为有符号数还是无符号数。
int m=(x+y>9)?1:0; 在这一条语句中,x是无符号数,y是有符号数,根据c语言的规定,有符号数和无符号数相加,数据类型都为无符号数。所以得到的
结果也为无符号数。那么x+y=245>0,所以m=1.
由于z=x+y,z为有符号数,那么编译器会将二进制结果解释为有符号数,那么z=-11.
第9条语句,if(y>x)
如果站在底层去看的话,会将y-x的值进行处理,因为y是有符号数,x是无符号数,
y-x=00000000 00000000 00000000 11101100
+11111111 11111111 11111111 11110111
=10000000 10000000 10000000 11100011
明显大于0,所以,y>x