转:原码、反码、补码和移码

我觉得,难点在于,怎样计算以及其作用

一、计算

运算过程:原码->反码->补码->移码

原码 :二进制(开头第一个表示符号0正1负)

反码 :在原码的基础上,符号位不动,其他位取反 ---注意,任何正数的源码=反码=补码,而负数都是通过补码表示的。 
补码 :在反码的基础上,运算+1  ---注意,任何正数的源码=反码=补码,而负数都是通过补码表示的。 
      公式:两数补码的和==两数和的补码。

移码 :在补码的基础上,符号位取反
101011(二进制)--> 原码 00101011 --> 反码 01010100 --> 补码 01010101--> 移码 11010101

二、作用

1 首先看源码
 问:什么是源码?
 答:数字的二进制形式(二进制的数)
 问:为什么要用源码?
 答:我是从2个方面看 1 从目前计算机的构造来看它只认识1/0,所以任何指令、数字、都会翻译成一个二进制数传递给计算机。
                 2 规范和统一计算机的“交流语言”,统一对外的接口。
总结:源码是计算机唯一认识的语言结构。

2 反码和补码
 问:反码是什么?
 答:在源码的基础上符号位不动,其他取反
 问:为什么要用反码?
 答:这个问题需要配合补码一起查看,因为补码=反码+1 所以一般的计算顺序为 源码-->反码-->补码
*问:补码是什么?
 答: 补码=反码+1(符号位参与运算) 
 问:为什么要用补码?
 答:为了进行做加减运算,因为计算机只有加法计算器,所以a-b的处理方式为a+(-b),而这过程中如果直接用源码进行计算会出现问题

 例1 10+(-10)= 0 (当使用源码进行计算减法)
  10(十进制) -- 00001010(源码)
 -10(十进制) -- 10001010 (源码)
  00001010+
  10001010
-----------
  1XXXXXXX ----->首先看到第一位是负数,显然不是我们想要的结果

例子2 10-11 (试试用减法直接做计算吧)
  10(十进制) -- 00001010(源码)
 -11(十进制) -- 10001011(源码)

 00001010-
 10001011
------------
 xxxxx11111----->可以看到貌似跟答案-1(十进制)差距还是比较明显的

现在我们尝试应用补码进行计算
例子3 10+(-10)=0 (使用补码)
 10(十进制) --- 00001010(源码)----同源码(反码)----同源码(补码)
-10(十进制) --- 10001010(源码)----11110101(反码)----11110110(补码)

00001010+    10的源码----注意正数用补码(值等同于源码)
11110110    -10的补码----注意负数用补码
---------
00000000    得到了0的补码

例子3 10-11 (使用补码)
 10(十进制) --- 00001010(源码)----同源码(反码)----同源码(补码)
-11(十进制) --- 10001011(源码)----11110100(反码)----11110101(补码)

 

00001010+    10的补码
11110101    -11的补码
------------
11111111---   得到了-1的反码

从这4个例子可以看出反码和补码使用的作用了,用于为二进制负数做运算时的一种转换。

再次总结运算过程
数值有正负之分,计算机就用一个数的最高位存放符号(0为正,1为负).这就是机器数的原码了.假设机器能处理的位数为8.即字长为1byte,原码能表示数值的范围为 127~(-127)

运算过程:原码->反码->补码->移码

原码 :二进制(开头第一个表示符号0正1负)

反码 :在原码的基础上,符号位不动,其他位取反 ---注意,任何正数的源码=反码=补码,而负数都是通过补码表示的。 
补码 :在反码的基础上,运算+1  ---注意,任何正数的源码=反码=补码,而负数都是通过补码表示的。 
      公式:两数补码的和==两数和的补码。

移码 :在补码的基础上,符号位取反
原文链接

猜你喜欢

转载自blog.csdn.net/lzg319/article/details/80775012
今日推荐