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

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • 白萝卜。 2017-06-05 09:09
    关注

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

    评论
  • qq_36336328 2017-06-05 09:09
    关注

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

    评论
  • shen_wei 2017-06-05 09:36
    关注

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

    评论
  • 凝视深空 2017-06-05 09:59
    关注

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

    评论
  • 凝视深空 2017-06-05 10:12
    关注

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

    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 (关键词-聊天软件)
  • ¥15 求大家看看这个编程的编法没有思路啊
  • ¥20 WSL打开图形化程序子窗口无法点击
  • ¥15 Jupyter Notebook 数学公式不渲染
  • ¥20 ERR_CACHE_MISS 确认重新提交表单
  • ¥20 关于vba使用HTMLfile执行js函数问题
  • ¥60 悬赏求解,通过实时现场摄像头的视频图像识别其他对家打出的麻将牌,识别麻将牌,识别牌墙位置,通过识别对家打出了什么牌
  • ¥15 关于#GPU jetson#的pcie驱动开发问题,如何解决?
  • ¥15 stm32f103zet6 串口5无法收发数据
  • ¥15 关于C语言使用线程队列实现多线程并发