在16位int平台下,输出是65534;在32位int平台下,输出是4294967294。以32位int平台为例,题中的unsigned int a=-2;语句在unsigned的修饰下,赋给变量a的是-2补码的无符号值,即4294967294。但后面的printf("%u",a);的输出并不与a是否为有符号数没有关系,输出是否为有符号数由"%u"中的控制符%u决定,这里%u表示将变量a按无符号数输出,所以输出是4294967294。因此,如果将unsigned int a=-2;改为int a=-2;,printf("%u",a);同样输出4294967294。即使是unsigned int a=4294967294;这样定义a,用printf("%d",a);输出就是-2;因为输出是由控制符%d决定的。
应该是4294967295-2+1=4294967294
因为unsigned int a=-2;这句会强制把负数,转换成正数
在VC等32位编译系统上-2的补码是11111111111111111111111111111110
若解释为unsigned int则为4294967294
同理unsigned int a=-2;printf("%d",a);虽然定义a是unsigned类型,但printf();函数中解释为int类型,输出结果还是-2。内存中的2进制数据不同的解释方式,有不同的显示结果。
输出结果为65534或者4294967294
因为在不同位的操作系统下,数值的表示位数是不一样的。首先我们先明确一点:在计算机中,正数用原码来计算(正数的原码、补码、反码都是一样的);负数是用补码来计算的。至于原因可以参考一下文章网页链接就是把减法简化为加法从而大大简化计算机电路的过程。
首先在16位系统中,-2的原码为1000 0000 0000 0010;补码为:1111 1111 1111 1110;我们使用的unsigned为无符号数,那么此时计算机会把我们的-2强制转化为正数进行运算,即用1111 1111 1111 1110表示-2,即为65534.
在32位操作系统中,-2的原码为:1000 0000 0000 0000 0000 0000 0000 0010;补码为:1111 1111 1111 1111 1111 1111 1111 1110;同上述,计算机会强制输出1111 1111 1111 1111 1111 1111 1111 1110所代表的十进制数,即4294967294。
可以参考一下例子:
#include
#include
void main()
{
unsigned int a=65535;
int b=4294967294;
printf("%d %u\n",a,a);
printf("%d %u\n",b,b);
system("pause");
}
输出结果:
65535 65535
-2 4294967294
unsigned int 为 0--65535
1111 1111 1111 1111 为 65535
-2用补码表示
1000 0000 0000 0010 取反加1
1111 1111 1111 1110
结果为 65534