源码;反码;补码的认识

原码:
▪原码是指将最高位作为符号位(0表示正,1表示负),其它数字位代表数值本身的绝对值的数字表示方式
–数字-6在计算机中原码表示为:1000 0110–数字6在计算机中原码表示为:0000 0110
▪以上是在8位计算机中的原码表示,如果在32位或16位计算机中,表示方法是一样的,只是多了几个0。
▪有了数值的表示方法就可以对数进行算数运算,但是很快就发现用带符号位的原码进行乘除运算时结果正确,而在加减运算的时候回出现问题,如下:
▪(00000001)原+(10000001)原=(10000010)原=(-2)
▪(1)10-(1)10= (1)10+(-1)10= (0)10
▪显然是不正确的

反码:
▪反码表示规则为:如果是正数,则表示方法和原码一样,如果是负数,则保留符号位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等其他高级语言中使用的都是原码)    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值