原码、补码、反码

原码
是指将最高位作为符号位(0表示正,1表示负),其它数字位代表数值本身的绝对值的数字表示方式
– 数字6在计算机中原码表示为:0000 0110
– 数字-6在计算机中原码表示为:1000 0110
▪ 以上是在8位计算机中的原码表示,如果在32位或16位计算机中,表示方法是一样的,只是多了几个0而已有了数值的表示方法就可以对数进行算数运算,但是很快就发现用带符号位的原码进行乘除运算时结果正确,而在加减运算的时候回出现问题,如下:
▪ (1)10 - (1)10 = (1)10+(-1)10 = (0)10
▪ (00000001)原+(10000001)原=(10000010)原=(-2)
▪ 显然是不正确的
 反码
表示规则为:如果是正数,则表示方法和原码一样,如果是负数,则保留符号位1,然后将这个数字的原码按照每位取反,则得到这个数的反码表示形式
– 数字6在计算机中反码就是它的原码:0000 0110
– 数字-6在计算机中反码为:1111 1001
▪ 因为在两个正数的加法运算中是没有问题的,于是就发现问题出现在带符号位的负数身上,对除符号位外的其余各位逐位取反就产生了反码,反码的取值空间和原码相同且一一对应,下面是反码的减法运算:
– (1)10-(1)10=(1)10+(-1)10=(0)10
– (00000001)反+(11111110)反=(11111111)反=(-0)有问题
– (1)10-(2)10=(1)10+(-2)10=(-1)10
– (00000001)反+(11111101)反=(11111110)反=(-1)正确
补码
▪ 问题出现在(+0)和(-0)上,在人们的计算概念中0是没有正负之分的
▪ 于是就引入了补码的概念,负数的补码就是对反码加一,而正数不变,正数的原码反码补码都是一样的,在补码中用(-128)代替了(-0),所以补码的表示范围为
– (-128~0~127),共256个
▪ 补码是计算机表示数据的一般方式,其规则为:如果是正数,则表示方法和原码一样,如果是负数,则将数字的反码加上1(相当于将原码数值按位取反然后在对地位加1)
▪ 注意:(-128)没有相对应的原码和反码,(-128)=(10000000)的补码的加减运算如下:
▪ (1)10-(1)10=(1)10+(-1)10=(0)10
▪ (00000001)补+(11111111)补=(00000000)补=(0) 正确
▪ (1)10-(2)10=(1)10+(-2)10=(-1)10
▪ (00000001)补+(11111110)补=(11111111)补=(-1) 正确
▪ 所以补码的设计目的是:
– 使符号位能与有效值部分一起参加运算,从而简化运算规则
– 使减法运算转换为加法运算,进一步简化计算机中运算器的线路设计
▪ 所有这些转换都是在计算机的最底层进行的,而在我们使用的汇编、C等其他高级语言中使用的都是原码
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值