深入理解原码,反码,补码

背景

本篇学习总结,我将为大家讲解什么是计算机中的原码,反码,补码;同时讲解了为什么要采用反码和补码的加法来计算原码的减法。

机器数和真值

在正式讲解编码的概念之前,先介绍两个术语:真值和机器数。

真值

现实生活中,人们使用的自然数,就代表真值。即真实世界的数值。

机器数

计算机用二进制来表示数据,而这个二进制数就叫做机器数。
为了让CPU数据的运算更加高效,真值需要编码后才能进行处理。机器数的表现形式如下所示:
例如真值: -1,
如用原码编码,机器数为: 1000 0001 (注意这里由于有符号位的原因,原码转换成十进制数是129,而真值是-1。)
反码编码: 1111 1110
补码编码: 1111 1111

原码、反码、补码的概念和运算

概念

对于真值-1,其

  1. 原码: 1000 0001。(原码由两部分构成:1位符号位+真值的二进制数值)
    原码可表示数据的范围: -127 ~ 127,字长为8时。
  2. 反码 : 1111 1110 (求-1的反码是符合号位不变,其余位取反。)
  3. 补码:1111 1111 (求-1的补码是在其反码的基础上,最低位加1。)

减法运算

我们先了解原码、反码、补码的减法运算:
计算机为了简化电路设计,把减法运算转成加法运算, 例如 1 - 1 , 转成加法运算: 1 + (-1) = 0; 用具体编码方式的形式来看,如下所示:

  1. 原码做减法: 0000 0001 + 1000 0001 = 1000 0010 = -2,-2不是我们要的真值0,所以原码不能进行减法运算。

  2. 我们再看看反码的减法运算:
    反码做减法:0111 1110 + 1111 1110 = 1000 0000 => -0

-0 != +0
-0 =1000 0000
+0= 0000 0000
我们可以发现 0000 0000 , 1000 0000都能表示0.所以反码不能唯一表示一个整数。

  1. 我们继续看看补码的减法运算:
    补码做减法:0111 1111+ 1111 1111 = 1000 0000 => -128 (约定1000 0000 等于-128)

为什么要用补码

从上面可知,有两个原因导致计算机采用补码来编码。

  1. 用原码做减法运算得到的结果不对。
  2. 而用反码做减法运算,当结果为0时,可能代表两个不多同的机器数。所以我们要用补码。
    用补码,即能让符号位参与运算,又能做减法运算。同时最小值范围相对于原码和补码要多一位,即 -2^ (n-1) ~ 2^(n-1). 如果是有符号位int32,则取值范围是[-2^31 ~ 2^ 31-1]

总结

本文介绍了什么是原码,反码,补码,以及如何把原码转化成补码和解释了为什么计算机选择补码作为编码方式。

参考资料

原码, 反码, 补码 详解

首先,我们需要了解如何将十进制转换成二进制原码反码补码。 1. **原码**:正直接表示,负则最高位为1(对于有符号整)。 - **95 (十进制)**: 原码 = 000001010101(因为95在8位内,不足8位补0) - **-131 (十进制)**: 原码 = 111110100011 (负最高位为1) 2. **反码**:对原码取反,然后加1(对于有符号整)。负反码是除符号位外全变1。 - **95 (十进制)**: 反码 = 111110101010 (+95的反码) - **-131 (十进制)**: 反码 = 000001011100 (-131的反码) 3. **补码**:也是对原码取反,然后加1,但对于负,有一个特殊情况:零的补码等于其本身。 - **95 (十进制)**: 补码 = 111110101010 (+95的补码,无需调整) - **-131 (十进制)**: 补码 = 000001011101 (-131的补码,注意最后一位由1变为0) 4. **浮点原码反码补码**: - **0.125 (十进制)**: 由于是小,通常会采用偏移二进制表示法,即在最高位后面跟上实际值的二进制。0.125 = 1 / 8 = 0.00011001... - 原码 = 000000000000011001000... (保留足够位) - 反码 = 11111111111110011111100... (先取反再加1) - 补码 = 11111111111110011111100... (小部分不变,不需要加1) - **-0.875 (十进制)**: 同样是小,可以将其转化为二进制形式 -0.125 * 8 = -1 = -1000... - 原码 = 100000000000001110000... (带符号,注意最左一位) - 反码 = 01111111111111000111100... (先取反再加1) - 补码 = 01111111111111000111100... (小部分不变,不需要加1)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值