重拾c语言

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

2017-05-03  本文已影响30人  edison0428
    

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


*   ####反码

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

*   ####补码
正数的补码就是其原码.
负数的补码就是在其反码的基础之上+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

上一篇 下一篇

猜你喜欢

热点阅读