C语言中如何运用原、反、补码

  今天来讲一讲在C语言中如何灵活的运用原码,反码,和补码,在开始讲之前,先讲一下什么是原码、反码和补码。原码、反码和补码

  我们知道,整数的二进制有三种表达方式:原码、反码和补码。对于正整数来说,原码、反码和补码相同,对于负整数来说,原码、反码和补码不同,需要进行相关的计算,那么这里就结合图片给大家讲解一下,假设现在创建一个整型变量int a = 5,给它赋值5,5用二进制写的话一共32个bit位,因为a是一个整型,占4个字节,4个字节一共有32bit位,所以a的原码、反码和补码就如下图所示:

   这里得出的结论就是,正整数的原码、反码和补码是相同的。

   对于二进制数列的最高位,也就是图片中最左边的这个0,表示的是整数,如果最高位是1,表示的就是负数,最高位就是符号位。

  那么现在假设a赋值为-5,此时原码的符号位就要变成1,反码的书写就是符号位不变,其他位按位取反,原来是0的变为1,原来是1的变为0,补码的书写就是反码这个二进制序列最低位加1即可,最终-5的原码、反码和补码如下图:

   讲完这三种形式之后,我们就探讨以下,内存中是以哪种形式存放整数的,这里可以告诉大家在内存中整数是以补码形式存储的。

  举个例子,我们知道-1的原码、反码和补码如下图所示:

   那么按照我刚才的说法,先记住-1的补码,然后我们写一段程序,然后运行测试以下,看看-1在内存中是如何存储的,程序如下:

   像上图中一样,运行程序后进入调试窗口,找到内存,然后我们&a,这里就可以看到显示的是4个ff,这里我们看到的是一个16进制的数,以为VS编译器在内存窗口是以16进制来展示的,那么16进制的f就代表15,15由2进制表示就是1111,所以这里一共4个ff,一共32个1,也就是刚才我让大家记下来的-1的补码。

    利用到这个原码、反

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值