原码、反码和补码


1.机器数和真值

(1)机器数:将一个数的绝对值用二进制表示,并在最前面加上符号位,非负数符号位为0,负数符号位为1
例如:+3=00000011、-3=10000011
(2)真值:将一个数的绝对值用二进制表示,并在最前面加上正负号
例如:+3=+00000011、-3=-00000011


2.原码、反码和补码

(1)原码:符号位加上真值的绝对值,即用第一位表示符号,其余位表示值(机器数)
例: [+1]原=00000001、[-1]原=10000001
(2)反码:正数的反码是其本身,负数的反码是在原码的基础上,符号位不变,其余位取反
例: [+1]=[00000001]原=[00000001]反
[-1]=[10000001]原=[11111110]反
(3)补码:正数的反码是其本身,负数的补码是在原码的基础上,符号位不变,其余位取反,然后再加1(反码+1)
例: [+1]=[00000001]原=[00000001]反=[00000001]补
[-1]=[10000001]原=[11111110]反=[11111111]补


3.计算机为何使用补码

正数的三码都一样,使用补码的原因主要在于用补码表示负数可以让符号位也参与运算。
(1)用原码计算加法:
1-1=1+(-1)=[00000001]原+[10000001]原=[10000010]原=-2
显然由于符号位参与运算导致运算结果不正确
(2)用反码计算加法:
1-1=1+(-1)=[00000001]反+[11111110]反=[11111111]反=-0
用反码计算会导致+0=[00000000]反和-0=[11111111]反的出现
(3)用补码计算加法:
1-1=1+(-1)=[00000001]补+[11111111]补=[00000000]补=0
解决了用反码计算出现+0和-0的问题。因为0用[00000000]补表示,[10000000]补就可以用来表示-128(8位有符号二进制最小的数)。但是将[10000000]补还原成原码为[00000000]原,表示的是0,因此-128没有对应的原码和反码。
(4)使用补码,修复了0的符号以及存在两个编码的问题,而且还能够多表示一个最低数。这就是为什么8位二进制,使用原码或反码表示的范围为[-127,+127],而使用补码表示的范围为[-128, 127]。最重要的是,将负数表示成补码的形式,可以连同符号位一起运算,而不会导致错误。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值