拖延症重症患者 2017-06-05 08:52 采纳率: 33.3%
浏览 3133
已采纳

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

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

  • 写回答

6条回答 默认 最新

  • 种瓜大爷 博客专家认证 2017-06-05 14:00
    关注

    计算机存储的时候是以补码的形式存进去的,输出来在以你原码的形式输出(这个形式就是你设置的形式)!
    比如: -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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?