计算机的原码,反码,补码是怎么回事?可以举例说明吗?

如题所述

原码、反码和补码是计算机中对数字二进制的三种表示方法。
1、原码
原码(true
form)是一种计算机中对数字的二进制定点表示方法。原码表示法在数值前面增加了一位符号位(即最高位为符号位):正数该位为0,负数该位为1(0有两种表示:+0和-0),其余位表示数值的大小。
例如:用8位二进制表示一个数,+11的原码为00001011,-11的原码就是10001011。
2、反码
反码是数值存储的一种,多应用于系统环境设置,如linux平台的目录和文件的默认权限的设置umask,就是使用反码原理。反码的表示方法是:正数的反码与其原码相同;负数的反码是对正数逐位取反,符号位保持为1。
例如:
[+7]反=
0
0000111
B;
[-7]反=
1
1111000
B。
3、补码
正数:正数的补码和原码相同。负数:负数的补码则是符号位为“1”。并且,这个“1”既是符号位,也是数值位。数值部分按位取反后再在末位(最低位)加1。也就是“反码+1”。
例如:
[+7]补=
0
0000111
B;
[-7]补=
1
1111001
B。
扩展资料
原码、反码、补码的转换方法如下:
(1)
已知原码,求补码。
例:已知某数X的原码为10110100B,试求X的补码和反码。
首先通过原码的首位确定该数字的正负,若为正数,反码与原码相同,补码比原码在末尾加1;若为负数,求其反码时,符号位不变,数值部分按位求反;求其补码时,再在其反码的末位加1。
(2)已知补码,求原码。
按照求负数补码的逆过程,数值部分应是最低位减1,然后取反。但是对二进制数来说,先减1后取反和先取反后加1得到的结果是一样的,故仍可采用取反加1的方法。
参考资料来源:百度百科-反码
参考资料来源:百度百科-补码
参考资料来源:百度百科-原码
温馨提示:答案为网友推荐,仅供参考
第1个回答  2020-01-07
计算机中的存储系统都是用2进制储存的,对我们输入的每一个信息它都会自动转变成二进制的形式,而二进制在存储的时候就会用到原码,反码和补码
例如:输入25
原码就是:0000000000011001
反码:
1111111111100110
补码:
1111111111100111
第2个回答  2022-07-22

在计算机系统中,数据,一律采用补码来表示和存储。

原因在于,使用补码,可以将加、减法,统一用加法运算。

原码和反码,都没有这个功能,所以,计算机中,并不使用它们。

补码,就是一个“代替负数进行运算”的正数。

比如时针,倒拨 3 小数,可以用正拨 9 小时代替。

比如限定用两位数(00~99)作计算,那么:

  25 - 1 = 24

  25 + 99 = (一百)  24

舍弃进位,只保留两位,+99 就可以代替-1 !

+99 就是-1 的补数。

计算机中用的是二进制,补数,就是补码了。

比如限定用八位数(0000 0000~1111 1111)作计算,那么:

-1 的补码,就是 1111 1111 (十进制 255)。

---------------

计算机的补码,是怎么回事?

  使用补码,能统一加减法,就能够简化硬件。

  为了简化硬件,补码,就是这么回事!

计算机的原码、反码,是怎么回事?

  计算机,根本就不用原码反码。

  原码反码,什么用处都没有。

第3个回答  2020-01-29
计算机以二进制补码存储数据
以16位机器为例:
比如83的二进制码为:0000
0000
0101
0011
由于正数的源码、反吗、补码,上面的既是源码,也是反码和补码
下面通过负数讲解源码、反码、补码之间的关系
以-83为例
先求出-83绝对值的源码:0000
0000
0101
0011
计算机区分正负数通过判断最高位符号位,1为负数、0为正数
那么-83的源码为:1000
0000
0101
0011
反码在源码基础上按位取反,符号位不变:1111
1111
1010
1100
补码在反码的基础上加1:1111
1111
1010
1101
补码转源码:补码基础上按位取反后加一,符号位在取反时不变,加一时最高位符号位有进位的,进位忽略
取反:1000
0000
0101
0010
加1:1000
0000
0101
0011
相似回答