美文网首页重拾c语言
C语言专题-原码、反码与补码

C语言专题-原码、反码与补码

作者: edison0428 | 来源:发表于2017-05-03 18:10 被阅读30次
  • 什么是原码、反码和补码

    我们知道,在计算机内部存储的带符号数都是以补码形式存储,用补码形式进行运算的,什么是一个数的补码?为什么要用补码?这要从数的原码、反码开始讲。

    • 原码

    为了可以表示正负性.使用最高为来表示这个数的正负性.
    如果最高为是0 那么表示这个数是1个正数
    如果最高为是1 那么表示这个数是1个负数.
    所以,来表示数据的只有31位. 所以,1个int类型的变量
    原码
    也叫 符号-绝对值码
    原码简单易懂
    加减运算复杂
    存在加减乘除四种与暗算
    零的表示不唯一,存在+0 -0

    int a =-100;
    printf("a==\n\t原码:\t%s\n\t补码:\t%s\n", OriCodeA, NegCodeA);
    int b=100;
    printf("b==\n\t原码:\t%s\n\t补码:\t%s\n", OriCodeB, NegCodeB);
    unsigned int c=100;
    printf("b==\n\t原码:\t%s\n\t补码:\t%s\n", OriCodeC, NegCodeC);
    结果:
    a==
      原码:10000000000000000000000001100100
     补码:11111111111111111111111110011100
       b==
    原码: 00000000000000000000000001100100
    补码: 00000000000000000000000001100100
     c==
    原码: 00000000000000000000000001100100
    补码: 00000000000000000000000001100100
    
    

最高位表示符号位. 剩下的位数.是这个数的绝对值的二进制


*   ####反码

正数的反码就是其原码. 
负数的反码就是在其原码的基础之上 符号位不变,其他位取反

*   ####补码
正数的补码就是其原码.
负数的补码就是在其反码的基础之上+1

*   ####二进制
我们都知道原码反码补码就是二进制,只不过是二进制的不同变现形式
数据正是以补码的形式储存在计算机中
正数的原码反码补码都是一样,那么我们来说说负数的


比如 :数值到二进制

int a = -10;
那么转成我们想要的二进制,也就是补码有四步
第一步:
先求出10的原码:0000 0000 0000 0000 0000 0000 0000 1010
第二步:
把符号位改成负数形势:1000 0000 0000 0000 0000 0000 0000 1010
第三步:
求出反码:1111 1111 1111 1111 1111 1111 1111 0101
第四步:
求补码:1111 1111 1111 1111 1111 1111 1111 0110
这个就是你用计算机对应出来的二进制


又比如:二进制到数值

传说中的 0x80000000,当然这个是指有符号的,无符号的没什么好说的
先说下答案:-2147483648
之前我也是一脸懵逼,仔细学习了下后,说下自己的思路,不对请指出

这个0x80000000的二进制为:1000 0000 0000 0000 0000 0000 0000 0000
因为是有符号的,高位为1表示负数,那么低31为0 表示数值,excuse me? 那么这个值为-0,no,这也太不人之常情,于是,正确答案讲解来了(我自己的理解,也不知道正不正确,尝试几个值都是对的)

这个0x80000000的二进制是补码,那么想要得到它对应的数值,就得逆向从原码到补码,有三步

第一步:
求反码:除符号位的补码-1
还是:1000 0000 0000 0000 0000 0000 0000 0000

第二步:
求原码:除符号位取反
1111 1111 1111 1111 1111 1111 1111 1111

第三步:
求数值:低31的二进制的值为2147483648,高位符号位为1则负数,那么是-2147483648

相关文章

  • C语言专题-原码、反码与补码

    什么是原码、反码和补码我们知道,在计算机内部存储的带符号数都是以补码形式存储,用补码形式进行运算的,什么是一个数的...

  • 软件测评师做题技巧

    第一类补码,反码,原码 正数:原码=反码;补码=原码负数:反码=原码求反;补码=反码+1 第二类用例概率的计算 测...

  • 原码、反码、补码和移码

    书中关于原码、反码、补码和移码的定义如下(n是机器字长):原码: 反码: 补码: 移码: 原码, 反码, 补码的基...

  • 2018-10-22 Python31 原码、反码、补码

    原码、反码、补码 1)如何计算补码?规则: 正数:原码 = 反码 = 补码负数:反码 = 符号位不变,其他位取反补...

  • 计算机为什么要使用原码、反码、补码

    1. 什么是原码、反码、补码 先看一个例子: +1和-1的原码、反码、补码的表示 原码、反码、补码的计算方式如下:...

  • 补码

    原码、反码、补码 原码:符号位 反码:减法变加法 补码:+1解决-0问题 数学原理 同余 反码:mod127 补码...

  • C语言 原码、反码、补码

    原码:最高位为符号位,其余各位为数值本身的绝对值。 反码:正数的反码与原码相同;负数的反码,符号位为1,其余位对原...

  • 按位异或运算 (正数异或负数) 、按位非(~)

    正数反码:与原码相同 负数反码:符号位为“1”,数值位按位 取反。 正数补码:与原码相同 负数补码:求反加一 记住...

  • 【计算机】我的收藏文章索引

    索引表 索引标题链接摘要原码、反码、补码《原码、反码、补码,详解》http://www.cnblogs.com/z...

  • [计基]-二进制之补码

    一.基础名词 原码 : 0011 反码 :0011(原码) >> 1100(反码) (原码按位取反) 补码 :00...

网友评论

    本文标题:C语言专题-原码、反码与补码

    本文链接:https://www.haomeiwen.com/subject/zotltxtx.html