qq_34886018
拖延症重症患者
采纳率33.3%
2017-06-05 08:52

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

已采纳

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

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

6条回答

  • czg13548930186 种瓜大爷 4年前

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

    点赞 3 评论 复制链接分享
  • coder_lj 凝视深空 4年前

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

    点赞 1 评论 复制链接分享
  • coder_lj 凝视深空 4年前

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

    点赞 评论 复制链接分享
  • shen_wei shen_wei 4年前

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

    点赞 评论 复制链接分享
  • qq_36336328 qq_36336328 4年前

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

    点赞 评论 复制链接分享
  • morgerton 白萝卜blb 4年前

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

    点赞 评论 复制链接分享

相关推荐