c语言中printf("%x",-1);为什么会输出-1的十六进制补码??

c语言中printf("%x",-1);为什么会输出-1的十六进制补码???

计算机存储的时候是以补码的形式存进去的,输出来在以你原码的形式输出(这个形式就是你设置的形式)!
比如: -1 (32位模式)
存:
1 000000000000000000000000000000 1<原>
1 111111111111111111111111111111 0<反-注意第一位是符号位不变>
1 111111111111111111111111111111 1<补>
输:<以有符号数输出且是负数 那么输出原码=补码再求补;其余输出原码=[补码]>
以%d形式<这是有符号数输出且是负数>:
1 111111111111111111111111111111 1<补>
1 000000000000000000000000000000 0<反>
1 000000000000000000000000000000 1<原>
第一为符号位为1 表示-,所以输出-1

以%x形式:<这是无符号数>:
1 111111111111111111111111111111 1<补>
1 111111111111111111111111111111 1<原>
不考虑符号所以,输出FFFFFFFF。

望采纳!
关于原码反码补码该概念请看我博客:http://blog.csdn.net/czg13548930186/article/details/72808385
了解小数在计算机内部如何存储可参考我博客:http://blog.csdn.net/czg13548930186/article/details/53433828

http://c.biancheng.net/cpp/html/293.html
%x 整数的参数会被转成无符号的十六进制数字,并以小写abcdef 表示

%x表示的就是以十六进制来输出,并且-1在电脑里本来就是按照FFFFFFFF来存放的,因为计算机内数字是按其补码来存放的,要用%d才会输出-1

VS08 输出的是FFFFFFFF 当成字符串输出的。。

至于为什么会是补码?在计算机系统中,数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数值域统一处理;同时,加法和减法也可以统一处理。此外,补码与原码相互转换,其运算过程是相同的,不需要额外的硬件电路。

因为-1在计算机里存储的值是补码,转化为原码还需要计算。我估计是出于方便计算机的目的才不转化的