1.原码,反码,补码的基础概念和计算方法

在搞清楚为什么计算机要使用补码之前,我们先搞清楚一个基本知识点,就是原码,反码,补码的计算方式。

对于一个数,计算机要使用一定的编码方式进行存储,原码,反码,补码是机器存储一个具体数字的编码方式。

原码

原码就是符号位加上真值的绝对值,即用第一位表示符号,其他为表示值。

比如8位二进制:
[+1]原 = 0000 0001
[-1]原 = 1000 0001
第一位是符号位,所以8位二进制数的取值范围是:
[1111 1111,0111,1111]

[-127,127]
原码是我们最容易理解的计算方式。

反码

正数的反码是其本身

负数的反码是在其原码的基础上,符号位不变,其余逐个取反
[+1]=[0000 0001]原=[0000 0001]反
[-1]=[1000 0001]原=[1111 1110]反
当反码表示一个负数的时候,人脑是无所直观得知他的数值,所以需要将其转化为原码再计算。

补码

正数的补码就是其本身

负数的补码是在其反码的基础上加1
[+1]=[0000 0001]原=[0000 0001]反=[0000 0001]补
[-1]=[1000 0001]原=[1111 1110]反=[1111 1111]补
同样,对于负数的补码,人脑是无所直观得知他的数值,所以需要将其转化为原码再计算。

2.为何要使用原码,反码,补码

首先要求大家要先掌握这三种编码的计算方式。
下面我们来关注负数的情况
[-1]=[1000 0001]原=[1111 1110]反=[1111 1111]补
既然原码才是我们直观最能识别的方式,为什么还要有反码和补码?

首先,因为人脑可以知道第一位是符号位,在计算的时候,我们会根据符号位,选择对数值的加减。但对于计算机,要让计算机辨别“符号位”显然会让计算机的基础电路设计变得非常复杂,所以人们想出了将符号位也参与运算的方法。
我们知道,减去一个正数等于加上一个负数,即1-1=1+(-1)=0,所以

计算机只有加法没有减法

,这样计算机的运算设计就更简单了。

所以,当我们计算1-1=0时,如果用原码的方式来计算结果如下:
1-1=1+(-1)=[0000 0001]原+[1000 0001]原=[1000 0010]原=-2

结论:如果用原码表示,让符号位也参与计算,显然结果是不对的,这就是为什么计算机内部不使用原码表示一个数。

为了解决原码做减法,反码出现了

1-1=1+(-1)=[0000 0001]原+[1000 0001]原=[0000 0001]反+[1111 1110]反=[1111 1111]反=[1000 0000]原=-0

发现使用反码计算减法,结果的数值是正确的。而现在的问题就出现在“0”这个特殊的数值上。虽然人是可以理解+0和-0是一样的,但是0带符号是没有任何意义的。
所以会出现[0000 0000]原和[1000 0000]原,两个编码都表示0

为了解决“0”的问题,补码出现了

1-1=1+(-1)=[0000 0001]原+[1000 0001]原=[0000 0001]反+[1111 1110]反=[0000 0001]补+[1111 1111]补=[0000 0000]补=[0000 0000]原

这样0就用[0000 0000]表示,而之前的-0则不存在。
那么[1000 0000]表示哪个数值,即-128
(-1) + (-127) = [1000 0001]原 + [1111 1111]原 = [1111 1110]反+[1000 0000]反=[1111 1111]补 + [1000 0001]补 = [1000 0000]补

所以在补码运算中 [1000 0000]补表示-128.
注意,实际上是使用以前的-0的补码来表示-128, 所以-128并没有原码和反码表示.(对-128的补码表示[1000 0000]补算出来的原码是[0000 0000]原, 这是不正确的)

使用补码, 不仅仅修复了0存在两个编码的问题, 而且还能够多表示一个最低数. 这就是为什么8位二进制, 使用原码或反码表示的范围为[-127, +127], 而使用补码表示的范围为[-128, 127].

JavaSE教程-03深入探究原码,反码,补码-扩展相关推荐

  1. 原码 反码 补码的简单计算附例题

    原码 反码 补码 对计算机中常见数据简单分类 机器数 与 真值 原码 反码 补码 扩展 对计算机常见数据的分类 机器数 就是数值在计算机中的二进制表现形式 机器数在计算机中有符号,使用 最高位表示符号 ...

  2. 原码, 反码, 补码, 移码 详解

    本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ...

  3. 大端 小端 原码 反码 补码 及内存中的表现

    小端 和 大端 在内存中存储时,都是从内存的低地址往高地址存,即0x00000000 -> 0xffffffff 以汉字 "严"为例,Unicode码是4E25,需要两个字节 ...

  4. python二进制反码例题_python中的进制转换和原码,反码,补码

    python中的进制转换和原码,反码,补码 计算机文件大小单位 b = bit 位(比特) B = Byte 字节 1Byte = 8 bit #一个字节等于8位 可以简写成 1B = 8b 1KB ...

  5. c语言原码 补码 反码,C语言 原码--反码--补码

    //原码,反码,补码 #include #include //数值的表示方法--原码.反码和补码 //原码:最高位为符号位,其余各位为数值本身的绝对值 //反码: //正数:反码与原码相同 //负数: ...

  6. 关于计算机中 原码, 反码, 补码 详解

    本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ...

  7. 关于 原码 反码 补码 位运算

    二进制 原码:最高位为符号位,0为正  1为负 正数的原码 反码 补码 都是相同的 反码:负数的反码为原码符号位不变 其它对应变化(1变0 0变1) 补码:等于 反码+1 3^-3 =? 运算过程 - ...

  8. 10.原码 反码 补码

    +7的原码:0000 0111 -7的原码:1000 0111   第一位0代表正数,1代表负数,第一位为符号位 +7的反码:0000 0111 正数反码和原码一样 -7的反码:1111 1000   ...

  9. java进制原码_Java 一一 进制、原码 反码 补码、移位操作

    进制 二进制 和 十进制 相互转换 十进制 和 十六进制 相互转换 原码,反码,补码 原码.反码.补码: 在计算机内, 有符号数有三种表示法: 原码, 反码, 补码. 所有的数据的运算都是采用 补码 ...

最新文章

  1. 名校算法博士找工作两月无果,因本科是不知名学校被婉拒
  2. 手把手带你入门 Spring Security!
  3. Spark查找某个IP的归属地,二分算法,try{}catch{}的使用,将结果存MySQL数据库
  4. Vue 监视属性 watch
  5. java poi打印word_Java 打印Word文档
  6. 2016-5-31 项目结构调整
  7. 树莓派4B开机自动挂载移动硬盘,以及遇到the root account is locked问题
  8. 如何获取母版页上控件的值?
  9. 【原型图设计工具】墨刀使用说明
  10. mysql 设置忽略大小写
  11. UE4渲染设置介绍(Rendering Setting)
  12. android 10.0禁用电源键(屏蔽关机短按长按事件)
  13. 使用DownloadManager进行更新下载,部分机型下载失败解决方案
  14. 向量空间,子空间,列空间,零空间(PartIII)
  15. background-position,有逗号和没逗号:截然不同的结果
  16. 销售如何快速有效获客?获客渠道和方式有哪些?
  17. JS计算今年过了多少天
  18. oracle会话临时表会造成死锁,Oracle Temporary Tables(Oracle 临时表)
  19. HTML5期末大作业:旅游网站设计——开心旅游网(15页) HTML+CSS+JavaScript 主题度假酒店
  20. 使用OpenSSL1.1.1中的libcrypto库进行RSA加密与解密数据

热门文章

  1. 区块链BaaS云服务(35)亦笔科技ODRChain
  2. 智能合约重构社会契约(7)以太坊总结
  3. (chap7 确保WEB安全的HTTPS) HTTPS和SSL
  4. 数据科学导论 考试有感 2019 山东大学
  5. python_面向对象进阶之slots
  6. [How TO]-python venv虚拟环境
  7. RtlAdjustPrivilege 一行代码提升进程权限
  8. java 解析 jar_解析java中对jar包进行再次修改
  9. 【web安全】你的open_basedir安全吗?
  10. 002 通过send断点分析功能call