首页 > 其他分享 >原码,反码,补码

原码,反码,补码

时间:2023-03-30 21:33:34浏览次数:34  
标签:0000 补码 1111 反码 原码 1000

0 为什么会出现原反补

0.1如果用原码计算会出现的问题

0000 0000 == +0
1000 0000 == -0
如果+0 +1 = +1 == 0000 0001 没有问题
如果-0 + 1 = +1 !=1000 0001 为-1 出现问题
如果-1 +1 = 0 != 1000 0010为-2 出现问题
所以用原码的方式计算负数的加减法,在十进制到二进制的逻辑上会出现错误

0.2 反码的诞生

为了解决上面用原码不能解决的问题,所以反码因此诞生
反码:正数反码不变,负数的反码在原码的基础上,符号位不变,数值取反

十进制 原码 反码 补码
+127 0111 1111 0111 1111 0111 1111
+3 0000 0011 0000 0011 0000 0011
+2 0000 0010 0000 0010 0000 0010
+1 0000 0001 0000 0001 0000 0001
+0 0000 0000 0000 0000 0000 0000
-0 1000 0000 1111 1111 0000 0000
-1 1000 0001 1111 1110 1111 1111
-2 1000 0010 1111 1101 1111 1110
-3 1000 0011 1111 1100 1111 1101
-127 1111 1111 1000 0000 1000 0001
-128 1000 0000

十进制计算:-3 +1 =-2
二进制原码计算: 1000 0011 + 0000 0001 = 1000 0100 转成十进制为 -4 显然不对
二进制反码计算: 1111 1100 + 0000 0001 = 1111 1101 (注意此时是反码)转成原码 为1000 0010 在转十进制为-2 结果正确
同理计算 -2+1=-1 ,-1+1=-0
-0+1 =+1 但是用反码来计算 却得出+0 出现新的问题
问题出现的主要原因:有-0,+0两种零,在二进制中是两个逻辑形式,在十进制中可以看成一种逻辑形式

0.3 补码的诞生

为了解决二进制两种逻辑零的问题,所以诞生了补码
补码:正数的补码是其本身,负数的补码是在反码的基础上+1
看上面表格中可知:-0和+0的二进制补码形式相同,解决了俩个零问题,还生成了一个特殊的-128它只有补码没有原码和反码。
最后所用问题得到解决,计算机决定用补码的形式来存储数据。
一个字节8bit在计算机中表现的数据范围为+127~-128 or 0111 1111 ~ 1000 0000(补码表示)

1 原码,反码,补码,移码互相之间转换

1.1 各种码概念

原码:十进制数据的二进制表现形式,最左边是符号位,0为正,1为负
反码:正数的反码不变,负数的反码是符号位保持不变,其余位取反
补码:正数的补码是其本身,负数的补码是在反码的基础上+1

1.2 转换规则

正数:原码,反码,补码互相转换码不变
负数:原码-->反码 符号位不变,数值位按位取反
反码-->补码 末位+1
原码<-->补码 从右往左找第一个1,这个1左边的所用**数值位**按位取反

1.3 码的范围

以1字节8bit为例子

各种码 合法范围 最大值 最小值 真值0的表示
原码 -127~127
-(27-1)~(27-1) 0111 1111 1111 1111 0000 0000
1000 0000
反码 -127~127
-(27-1)~(27-1) 0111 1111 1000 0000 0000 0000
1111 1111
补码 -128~127
-27~(27-1) 0111 1111 1000 0000 0000 0000

标签:0000,补码,1111,反码,原码,1000
From: https://www.cnblogs.com/spirittimo/p/17274396.html

相关文章

  • 【C版本】静态通讯录与动态通讯录的实现,以及各自所存在的缺陷对比。(含所有原码)
    @​​TOC​静态版本通讯录前期思路与之前的扫雷以及三子棋的实现方式是一样的,创建两个源文件,一个用来测试,一个用来存放函数定义,再创建一个头文件,用来存放函数声明。接下来是......
  • 字符串的反码【吉林大学考研机试题】
    字符串的反码一个二进制数,将其每一位取反,称之为这个数的反码。下面我们定义一个字符的反码。如果这是一个小写字符,则它和字符a的距离与它的反码和字符z的距离相同;如......
  • 原码反码补码
    计算机存储的是数据的补码原码数据的二级制形式。例如123的原码:01111011无符号数:原码==反码==补码123原码:01111011123反码:01111011123补码:01111......
  • 原码、反码、补码
    一、位运算符(一)真值表位运算符作用于位,并逐位执行操作。“与”“&”、“或”“|”和“异或”“^"的真值表如下所示:pqp&qp|qp^q000000101111......
  • 随堂测补码
    修改界面:<%@pagelanguage="java"contentType="text/html;charset=UTF-8"pageEncoding="UTF-8"%><!DOCTYPEhtml><html><head><metacharset="UTF-8">......
  • byte,short,int等类型的转换以及原理,原码,反码,补码
    理论:八个比特(Bit)称为一个字节(Byte),最大[11111111],即FF;两个字节称为一个字(Word,Short),最大[1111111111111111],即FFFF,两个字称为一个双字(Dword,Int),最大[1111111111111111......
  • 补码
    为什么补码等于反码+1-简书(jianshu.com)我们必须要了解的Java位运算(不仅限于Java)-陈咬金-博客园(cnblogs.com)......
  • 二进制表示:原码、反码、补码详解
    本文主要介绍计算机中二进制的表示方法,详细介绍了十进制转二进制的方法,以及原码、反码和补码的不同和应用。一、二进制的计算要进行二进制的表示,首先需要进行计算二进制......
  • 5.3.2_原补码的除法运算
    @目录一、介绍二、原码的除法运算(1)手算除法之十进制1.过程2.原理(2)手算除法之二进制1.过程2.原理(3)机器实现1.恢复余数法原理过程手算模拟总结2.加减交替法恢复余数法简化举......
  • 5.3.1_原补码的乘法运算
    @目录一、原码乘法运算(1)手算乘法1.十进制乘法2.二进制乘法3.一些问题(2)机器实现1.案例2.确定符号位3.绝对值相乘的机器实现4.补充说明(3)手算模拟原码一位乘法二、补码乘法运......